Web 开发入门

本文整理自『MDN Web 开发入门』

本文由如下几个小节组成,通过依次对各个小节的学习,我们将从零开始开发一个网页,并将其上线。

  • 基础软件安装

    安装基础 Web 开发所需的软件。

  • 网页设计

    编写代码前,应对网页展示的内容、字体的类型及颜色有一个初步的规划与设计。

  • 文件编排

    为组成一个网站的诸多文件(如:代码文件、样式表文件与媒体文件等)进行合理的编排。

  • HTML 基础

    HTML(Hypertext Markup Language,超文本标记语言)是用于构建 Web 内容的标准语言。使用其来控制诸如:一组文本上方应有图片,文本下方应有一个表格。

  • CSS 基础

    CSS(Cascading Stylesheets,层叠样式表)是用于定义网站样式的代码。使用其来定义诸如:网页的背景图片、文本的颜色和模块的位置。

  • JavaScript 基础

    JavaScript 是用于为网站添加交互功能的编程语言。使用其来控制诸如:输入表单或点击按钮后应发生的事情。

  • 网站发布

    Web 网站编码完成后,可将其发布到服务器上。这样,人们就可以通过网址对其进行访问了。

  • Web 工作机制初探

    当访问一个网站时,其背后的机制会比较复杂。本文会概述访问一个网站时所发生的事情。

1 基础软件安装

本小节会介绍进行基础 Web 开发所需的软件或工具。

专业人士都用啥工具?

  • 一台电脑

    一个专业的 Web 开发人员应有一台运行 Windows、macOS 或 Linux 的台式机或笔记本电脑。

  • 一个文本编辑器

    一个用来编写代码的文本编辑器。诸如 Visual Studio CodeNotepad++Sublime TextAtomGNU EmacsVIM 等文本编辑器;或诸如 DreamweaverWebStorm 等混合编辑器。

  • 一个 Web 浏览器

    一个用来测试代码的 Web 浏览器。最常用的有 ChromeFirefoxOperaSafariInternet ExplorerMicrosoft Edge

  • 一个图形编辑器

    一个用来为网站制作图像或图形的编辑器。诸如 GIMPFigmaPaint.NETPhotoshopSketchXD

  • 一个版本控制系统

    一个用来进行代码管理及团队协作的工具。Git 及基于其衍生的 GitHub 托管服务是目前最流行的版本控制系统。

  • 一个自动化工具

    一个用来执行重复性任务(如:压缩代码或运行测试)的自动化工具。常见的有 WebpackGruntGulp

此外,还可能会涉及一些常用的库或框架等,基于其可以加快功能的实现。

现在需要用啥工具?

针对本文的练习,只需安装好一个文本编辑器和一个浏览器即可。

2 网页设计

编写代码前必须要考虑清楚的问题 —— 做一个什么样的网站?展示哪些信息?采用何种字体和色调?本小节会给出一个大概的着手办法。

  • 规划基础内容

    想一想,做一个关于什么的网站?美食?健身?旅游? 选好主题后,写上标题和几段话,并考虑想在页面上显示的一幅图片。 接下来,构思网站应该长什么样?采用什么背景颜色?何种字体?

    小提示:大型项目一般需要一套详尽的设计指导手册,包括颜色、字体、页面模块间的间距等都有严格的要求。业界一般叫作设计系统。诸如 Firefox 的 Photon Design System、IBM 的 Carbon Design System 和 Google 的 Material Design

  • 勾勒网站的轮廓

    接下来,拿起纸和笔试着勾勒出网站的雏形(这个习惯很重要)。

    手绘网站雏形 - developer.mozilla.org

    小提示:即使对于现实场景的复杂网站设计,设计团队也通常会先在纸上构思网站的轮廓。

  • 选择字体和色调

    现在,将之前规划的内容(标题、段落和图片等)组织到一起。

    借助『取色器』选择喜欢的颜色(颜色采用 6 位十六进制代码表示,诸如#660066),并记录好。

    Color Picker - developer.mozilla.org

    借助『谷歌图片』找一张喜欢的图片(诸如firefox-logo.png),并保存好。

    Google Images - developer.mozilla.org

    借助『Google Fonts』寻找喜欢的字体,并记下来。

3 文件编排

一个网站由诸多文件组成,有文本内容、代码、样式表和媒体文件等。我们需要将这些文件按照一个合理的结构组织在一起。本小节会探讨文件的组织及注意的问题。

  • 创建网站文件夹

    在磁盘的某个位置,创建一个名为诸如workspace的文件夹,用于存放所有的项目代码;在其下创建一个诸如test-site的文件夹,用于本次的练习。

    文件及文件夹命名小提示:因浏览器、服务器与编程语言对空格的处理不一致,且因一些服务器是大小写敏感的,所以进行文件或文件夹命名时,不要使用空格及大小写混合方式。建议直接使用全小写字母加短横线的方式进行文件及文件夹命名。如test-site/my-file.html即是一个规范的命名方式。

  • 编排网站目录结构

    接下来,考虑如何编排网站的目录结构。

    一个 Web 项目中常见的文件有:index.html文件、图像文件、CSS样式文件与JavaScript脚本文件。

    因此,一个初步的网站目录结构如下所示:

    test-site
    |--- images      # 存放所有的图片文件
    |     \--- firefox-logo.png
    |--- styles      # 存放所有的 CSS 样式文件
    |--- scripts     # 存放所有的 JavaScript 脚本文件
    \--- index.html  # 网站主页
    
  • 指定文件引用路径

    要使文件可以正确的找到对方,需要指定好文件的路径。下面,在index.html文件引用前面找好的图片firefox-logo.png

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="utf-8" />
        <title>My test site</title>
      </head>
      <body>
        <img src="images/firefox-logo.png" alt="My test image" />
      </body>
    </html>
    

    index.html保存好后,使用浏览器打开,效果如下图所示:

    Website Screenshot - developer.mozilla.org

4 HTML 基础

HTML(HyperText Markup Language,超文本标记语言)用于构建网页的内容,如使用一组文字段落、一组列表、一组图片或几张表格构成一个网页。本小节会对 HTML 和其功用有一个基本的介绍。

到底啥是 HTML?

HTML 是定义网页内容结构的一种标记语言。HTML 由一系列元素组成,这些元素用于封装内容的不同部分,以使其按照某种方式显现。闭合标签可以做诸如控制文本或图片超链接到某个地方及控制字体的大小等各种事情。

比如,想让一句话独立显示,可以使用<p></p>段落标签将其包起来:

<p>My cat is very grumpy</p>
  • HTML 元素剖析

    下面剖析一下刚刚用到的段落元素。

    Grumpy Cat Small - developer.mozilla.org

    可以看到,这个段落元素由开始标签、结束标签和内容这几个部分组成。

    开始标签(这里的<p>)表示元素从哪里开始(这里表示段落开始的地方);结束标签(这里的</p>)表示元素到哪里结束(这里表示段落结束的地方);元素内容即表示元素的内容(这里的一句话)。

    小提示:忘加结束标签是初学者常犯的错误之一,会导致各种奇怪的结果,所以要多加注意。

    此外,元素还可以有属性。示例如下:

    Grumpy Cat Attribute Small - developer.mozilla.org

    属性包含您不希望出现在实际内容中的额外元素信息。这里的class是属性名,editor-note是属性值,使用class属性可以控制元素的样式。

  • 元素嵌套

    用一组元素包含另一组元素,叫作元素嵌套。

    如下示例,在段落元素内使用<strong></strong>元素将单词very特别强调。

    <p>My cat is <strong>very</strong> grumpy.</p>
    

    小提示:使用元素嵌套时,要注意元素开闭的顺序,确保使用正确。

  • 空元素

    有些元素没有内容,称为空元素。前面在index.html用到的<img>元素即是一个空元素。

    <img src="images/firefox-icon.png" alt="My test image" />
    

    可以看到,该元素有两个属性srcalt,没有结束标签</img>,也没有内容。这是因为,图像元素不需要有文本内容,其目的是将图片嵌入 HTML 页面的某一处。

  • HTML 文档剖析

    下面剖析一下前面已见过的index.html文件的内容,看看多个独立的元素如何组合到一起形成一个完整的 HTML 页面。

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="utf-8" />
        <title>My test page</title>
      </head>
      <body>
        <img src="images/firefox-icon.png" alt="My test image" />
      </body>
    </html>
    

    <!DOCTYPE html>

    标准写法,没什么可说的,表示文档类型。

    <html></html>

    <html>元素,包含页面的所有内容,称为根元素。

    <head></head>

    <head>元素,包含页面需要使用的,但不向页面访问者直接显示的所有内容。包含诸如:关键字、页面描述、CSS 文件路径和字符集声明等。

    <meta charset="utf-8">

    此元素说明该网页使用的字符集为UTF-8(该字符集可以兼容世界上绝大多数国家的文字)。

    <title></title>

    <title>元素,用于设置页面的标题(页面加载完成后,浏览器选项卡中的标题)。

    <body></body>

    <body>元素,其包含需要向页面访问者显示的所有内容,包含文本、图像与视频等。

图像

再次将注意力转回到<img>元素。

<img src="images/firefox-icon.png" alt="My test image" />

正如前面所讲,该元素将一个图片嵌入到页面的某个位置。其通过src(source)属性指定了图片的路径;通过alt(alternative)属性为因某种原因(比如图片路径不对)看不到图片的用户显示一段描述。

文本标记

该部分将介绍用于标记文本的几个基本元素。

  • 标题

    标题元素用于将一段内容指定为标题或子标题。HTML 文档有 6 个标题级别<h1> - <h6>,通常最多用到 3-4 个。

    <!-- 4 heading levels: -->
    <h1>My main title</h1>
    <h2>My top level heading</h2>
    <h3>My subheading</h3>
    <h4>My sub-subheading</h4>
    

    小提示:HTML 中使用<!-- ... -->作注释,浏览器显示页面时会将其忽略。

  • 段落

    如前面所讲,<p>元素用于标记文本段落,即常规文本内容。

    <p>This is a single paragraph</p>
    
  • 列表

    HTML 为列表内容分配了专门的元素。常见的有有序列表和无序列表两种类型。

    无序列表(对应<ul>元素)用于对顺序无关紧要的场景(如:购物列表);有序列表(对应<ol>元素)用于对顺序重要的场景(如:食谱步骤)。

    列表中的每个条目都被包在一个<li>元素中。

    示例如下:

    <p>At Mozilla, we're a global community of</p>
    
    <ul>
      <li>technologists</li>
      <li>thinkers</li>
      <li>builders</li>
    </ul>
    
    <p>working together ...</p>
    
  • 链接

    链接很重要,其是 Web 成为 Web 的关键所在。

    要添加一个链接,使用<a>(anchor 的缩写,意思是“锚”)元素即可。

    示例如下:

    <a href="https://www.mozilla.org/en-US/about/manifesto/">Mozilla Manifesto</a>
    

    这里的<a>元素使用href属性指定要链接到的一个网址。

    小提示href为 Hypertext Reference 的缩写,即超文本引用。

本小节的内容跟着一步步走下来,最终看到的页面如下图所示(比对下index.html的源码)。

Finished Test Page - developer.mozilla.org

5 CSS 基础

CSS(Cascading Style Sheets,层叠样式表)是为网页内容添加样式的代码。诸如:如何使文本显示为红色?如何使内容显示在网页布局的某个位置?如何给网页指定背景图片或背景颜色?都是使用 CSS 来实现的。本小节将会对 CSS 的基础使用作一个介绍。

到底啥是 CSS?

CSS 与 HTML 一样,都不是编程语言。CSS 是一种样式表语言,是用来选择性设置 HTML 元素样式的工具。

如下示例使用 CSS 将文本段落设置为红色:

p {
  color: red;
}

现在做几点改动,看一下效果:

① 使用文本编辑器,将如上 3 行 CSS 代码拷入styles目录下的style.css文件中;

② 编辑index.html,将如下代码粘贴在<head></head>标签之间;

<link href="styles/style.css" rel="stylesheet" />

③ 保存index.html,并再次使用浏览器打开,即可看到如下效果。

Website Screenshot Styled - developer.mozilla.org

  • CSS 规则集剖析

    下面剖析一下上面的 3 行 CSS 代码,以了解其运作机制。

    CSS Declaration - developer.mozilla.org

    整个结构称为一个规则集。主要有如下几个部分组成:

    ① 选择器

    出现在规则集头部,说明要为哪些 HTML 元素指定样式(本例中,是为<p>元素指定样式)。

    ② 声明

    单个规则(如这里的color: red),指定设置元素的哪些属性。

    ③ 属性

    待设置的属性(本例中,color<p>元素的属性)。

    ④ 属性值

    待设置的属性值(如这里将颜色设置为red,还可以选择别的颜色)。

    此外,需要注意:除了选择器,规则集需要使用花括号括起来;每个声明中,须使用冒号将属性与其值隔开;声明之间使用分号分隔。

  • 多个元素选择

    可将一个规则集应用到多个 HTML 元素上(只需将多个选择器按逗号分开即可)。

    p,
    li,
    h1 {
      color: red;
    }
    
  • 选择器的类型

    上面示例中使用的是元素选择器,此外还有其它类型的选择器,下面列出常见的选择器类型:

    选择器名选择的目标示例
    元素选择器(有时也称为标签或类型选择器)指定类型的所有 HTML 元素p选择<p>
    ID 选择器页面上具有指定 ID 的元素(同一页面上 id 应唯一)#my-id选择<p id="my-id"><a id="my-id">
    类选择器页面上具有指定类的元素(同一页面上可以有相同类名的多个实例).my-class选择<p class="my-class"><a class="my-class">
    属性选择器页面上具有指定属性的元素img[src]选择<img src="myimage.png">而非<img>
    伪类选择器页面上在指定状态的指定元素a:hover选择仅当鼠标指针悬停在链接上的<a>

    此外,还有其它的选择器可供探索。详情请参阅『MDN 选择器指南』

字体与文本

现在有了 CSS 的一些基础知识,我们可以接着在style.css文件试着加入更多的规则来丰富示例页面的外观。

① 修改index.html文件

找到前面『网页设计』小节选好的字体,使用<link>元素将其放在标签<head></head>之间。

<link
  href="https://fonts.googleapis.com/css?family=Open+Sans"
  rel="stylesheet"
/>

如上代码将Open Sans字体加载到了页面。

② 清除style.css文件现有规则集

③ 将如下规则集添加到style.css文件

html {
  font-size: 10px; /* px means "pixels": the base font size is now 10 pixels high  */
  font-family: "Open Sans", sans-serif; /* this should be the rest of the output you got from Google fonts */
}

如上代码指定了页面的字体大小与类型。因<html>是整个页面的父元素,所以该页面所有的元素都会继承该font-sizefont-family设置。

小提示:CSS 中使用/* ... */作注释,浏览器在渲染页面时同样会忽略它们。

④ 更改元素样式

h1 {
  font-size: 60px;
  text-align: center;
}

p,
li {
  font-size: 16px;
  line-height: 2;
  letter-spacing: 1px;
}

如上代码指定了<h1><li><p>元素的字体大小,且让<h1>元素居中,并指定了<li><p>的行高与字母间距以使内容更具可读性。

样式调整后的页面效果如下图所示:

Website Screenshot Styled - developer.mozilla.org

关于“框”的一切

编写 CSS 时,大家可能会注意到:很多都是关于“框”的。包括设置尺寸、颜色和位置。页面上的众多 HTML 元素可被认为是建在“框”上面的“框”。

CSS 布局主要是基于“框”模型实现的。占用页面空间的每个“框”都具有以下属性:

padding(内边距)

边框与元素内容之间的空间。

border(边框)

内边距外的边框(实线)。

margin(外边距)

元素边框外的空白区域。

Box Model - developer.mozilla.org

此外,本小节还会用到:width(元素宽度)、background-color(元素内容和padding的背景色)、color(元素内容的颜色)、text-shadow(元素内的文本的投影)与display(元素的显示模式)。

接下来,继续在style.css文件添加更多的规则集,看看页面外观有什么变化。

  • 改变页面背景色

    html {
      background-color: #00539f;
    }
    

    如上规则集为整个页面设置了背景颜色。

  • 给页面 body 指定样式

    body {
      width: 600px;
      margin: 0 auto;
      background-color: #ff9500;
      padding: 0 20px 20px 20px;
      border: 5px solid black;
    }
    

    width: 600px;

    强制设定页面 body 的宽度为 600 像素。

    margin: 0 auto;

    设定marginpadding时,值可以为 1 ~ 4 个。 1 个值时,表示应用到所有四个方向; 2 个值时,分别表示垂直和水平; 3 个值时,分别表示上、水平、下; 4 个值时,分别表示上、右、下、左。

    本例中,margin的设置仅有两个值,表示将页面 body 垂直方向的外边距设置为 0,水平方向的外边距设置为自动平分。

    background-color: #FF9500;

    设置页面 body 的背景颜色。

    padding: 0 20px 20px 20px;

    设置页面 body 上、右、下、左的内边距为 0、20 像素、20 像素、20 像素。

    border: 5px solid black;

    设置页面 body 边框的宽度、样式和颜色。这里,给页面 body 设置了一个 5 像素宽的实心黑色边框。

  • 给页面标题指定位置与样式

    h1 {
      margin: 0;
      padding: 20px 0;
      color: #00539f;
      text-shadow: 3px 3px 1px black;
    }
    

    您可能注意到 body 顶部有一块很大的空白,这是因为浏览器对<h1>元素添加了默认的样式。 如上 CSS 代码首先使用margin: 0;将外边距设置为了 0,覆盖了浏览器的默认样式。 接下来,使用padding: 20px 0;将上、下内边距设置为了 20 个像素。 然后,使用color: #00539F;将标题颜色设置为了跟 html 背景色一样的颜色。 最后,使用text-shadow: 3px 3px 1px black;为标题设置阴影。text-shadow的四个值分别表示:水平偏移量、垂直偏移量、阴影模糊半径、阴影颜色。

  • 图片居中对齐

    img {
      display: block;
      margin: 0 auto;
    }
    

    接下来,同样使用margin: 0 auto;结合display: block;将图片水平居中。

    <body>是一个块元素,这意味着它会占用页面上的空间。应用于块元素的边距同样会被页面上的其它元素遵循。相比之下,图像是内联元素,要让自动边距设置在此图像上起作用,必须结合使用display: block;将其指定为块级行为。

    小提示:如上设置假定图片的宽度小于 body 的宽度(600 像素),若图片宽度大于 600 像素,则会溢出到 body 的外边。这时,可以使用<img>元素的width属性来调整图片的显示宽度。

    小提示:若现在对display: block;或块元素和内联元素之间的区别不太理解,也不必太担心。随着对 CSS 学习的深入,就会明白了。

本小节的内容跟着一步步走下来,最终看到的页面如下图所示(比对下style.css的源码)。

Website Screenshot Final - developer.mozilla.org

6 JavaScript 基础

JavaScript 是一种为网站增加交互性的编程语言。如控制按钮点击或表单输入后的行为以及作样式的动态控制等事情。本小节会对 JavaScript 的基础作一介绍。

到底啥是 JavaScript?

JavaScript 由 Brendan Eich(Mozilla 联合创始人)发明,其语法简单且应用广泛,可以用来做很多事情。

Hello world 样例

下面,使用 JavaScript 将页面标题动态修改为“Hello world”。步骤如下:

① 在网站根目录的scripts文件夹下新建main.js,并将如下代码拷入文件中。

const myHeading = document.querySelector("h1");
myHeading.textContent = "Hello world!";

② 编辑index.html文件,将如下代码加入</body>标签前。

<script src="scripts/main.js"></script>

这与使用<link>元素引入 CSS 一样,其将 JavaScript 引入页面,因此可以对 HTML (包括页面上的 CSS)产生影响。

这样,使用浏览器重新加载index.html页面,即会看到如下效果:

Hello World - developer.mozilla.org

小提示:将<script>元素放置在 HTML 文件底部的原因是由于浏览器按照文件中代码的先后顺序来读取代码,这样做是为了保证 HTML 加载完成后再加载 JavaScript。若将 JavaScript 放在待控制 HTML 的前面,就不会达到该效果。详情请参阅『JavaScript 加载策略』

可以看到,标题被更改为了“Hello world!”。下面,解释一下上面这段 JavaScript 的作用:

使用querySelector()函数获取对标题的引用,然后将其存储在名为myHeading的变量中;接着,代码将myHeading变量的textContent属性(表示标题的内容)值设置为Hello world!

小提示querySelector()方法及textContent属性均属 DOM(Document Object Model,文档对象模型)API 的一部分,其具有操作文档的能力。

JavaScript 快速入门

为了更好的理解 JavaScript 的工作原理,下面简单过一下其核心特性。

  • 变量

    变量为存储值的容器。可使用let关键字声明一个变量:

    let myVariable;
    

    关于变量命名规则,请参阅『JavaScript 变量』

    JavaScript 是大小写敏感的。所以myVariablemyvariable不同。

    变量声明后,可以为其赋值:

    myVariable = "Bob";
    

    也可以同时进行声明和赋值:

    let myVariable = "Bob";
    

    变量可以持有的值的数据类型如下:

    变量类型说明示例
    String字符串let myVariable = 'Bob';
    Number数值let myVariable = 10;
    Boolean布尔值let myVariable = true;
    Array数组let myVariable = [1, 'Bob', 'Steve', 10];
    Object对象,JavaScript 中的一切都是对象,都可以存储在变量中let myVariable = document.querySelector('h1');
  • 注释

    JavaScript 中分别使用/* ... *///作多行与单行注释,浏览器会忽略标记为注释的文本。

  • 运算符

    运算符是基于两个值(或变量)来做计算的数学符号。下表列出 JavaScript 中常用的运算符:

    运算符说明示例
    +(加)将两数相加或将两个字符串合并6 + 9;
    'Hello ' + 'world!';
    -(减)、*(乘)、/(除)基础数学运算9 - 3;
    8 * 2;
    9 / 3;
    =(赋值)将值赋给一个变量let myVariable = 'Bob';
    ===(相等)测试两个值是否相等let myVariable = 3;
    myVariable === 4
    !(非)、!==(不相等)返回与之前逻辑相反的值let myVariable = 3;
    !(myVariable === 3); // 为 false

    let myVariable = 3;
    myVariable !== 3; // 为 false

    JavaScript 中完整的运算符列表请参阅『JavaScript 表达式与运算符』

    小提示:做运算时,混合数据类型会导致一些奇怪的结果。如:'35' + '25'会被认为是字符串连接,而不会将两数相加。所以在引用变量时,要多加注意其类型。

  • 条件语句

    条件语句用来测试表达式是否为true。常见的条件语句是if ... else。示例如下:

    let iceCream = "chocolate";
    if (iceCream === "chocolate") {
      alert("Yay, I love chocolate ice cream!");
    } else {
      alert("Awwww, but chocolate is my favorite...");
    }
    

    如上示例中,若表达式iceCream === "chocolate"true,则运行第一个代码块;否则,运行else代码块。

  • 函数

    函数是一种重用代码的方式。

    函数通常带有参数,参数使用括号括起来。若有多个参数,则用逗号分隔。如下示例定义了一个将两数相乘的函数:

    function multiply(num1, num2) {
      let result = num1 * num2;
      return result;
    }
    

    调用方式如下:

    multiply(4, 7);
    multiply(20, 20);
    multiply(0.5, 3);
    

    小提示return语句告诉解释器从函数中返回结果变量,以便结果可以被使用。

  • 事件处理

    在网站上实现交互需要事件处理器的帮助。事件处理器会监听指定的行为,当行为发生时即会触发响应。典型的例子是浏览器的点击行为处理器。

    下面,将如下代码在浏览器 Console 中执行。然后点击当前页面,看看效果。

    document.querySelector("html").addEventListener("click", function () {
      alert("Ouch! Stop poking me!");
    });
    

    如上代码先选择<html>元素,然后调用其addEventListener()函数,传入一个要监听的事件名称(点击事件)和事件发生时要运行的函数。

    这里传递给addEventListener()的函数称为匿名函数(因其没有名称)。还有另一种编写匿名函数的方法,称之为箭头函数。箭头函数使用() =>代替function ()

    document.querySelector("html").addEventListener("click", () => {
      alert("Ouch! Stop poking me!");
    });
    

完善示例网页

对 JavaScript 基础进行速览后,接着使用其向示例网页添加一些新功能。

开始之前,先删除main.js文件现有内容。

  • 添加图像切换器

    现在使用 JavaScript 和 DOM API 来实现一个图片交替显示的功能。

    ① 选择一张与firefox-logo.png大小相近的图片,将其命名为firefox2.png,同样放在网站根目录的images文件夹下。

    ② 将如下 JavaScript 代码拷贝至文件main.js中。

    let myImage = document.querySelector("img");
    
    myImage.onclick = function () {
      let mySrc = myImage.getAttribute("src");
      if (mySrc === "images/firefox-logo.png") {
        myImage.setAttribute("src", "images/firefox2.png");
      } else {
        myImage.setAttribute("src", "images/firefox-logo.png");
      }
    };
    

    使用浏览器重新加载index.html页面,点击图片,将看到当前图片会被切换为另一张不同的图片。

    这是因为,我们使用myImage变量存储了对<img>元素的引用。然后,为onclick事件指定了一个匿名函数。该函数拿到图片的src属性值,判断其若与当前图片地址一样就改变其为另一张图片地址。

  • 添加欢迎信息

    接下来,使用 JavaScript 将页面标题更改为一个与登录用户相关的个性化欢迎语。

    ① 修改index.html文件,在<script>元素前增加如下代码。

    <button>Change user</button>
    

    ② 修改main.js文件,在底部加入如下代码。

    let myButton = document.querySelector("button");
    let myHeading = document.querySelector("h1");
    
    function setUserName() {
      let myName = prompt("Please enter your name.");
      if (!myName) {
        setUserName();
      } else {
        localStorage.setItem("name", myName);
        myHeading.textContent = "Mozilla is cool, " + myName;
      }
    }
    
    if (!localStorage.getItem("name")) {
      setUserName();
    } else {
      let storedName = localStorage.getItem("name");
      myHeading.textContent = "Mozilla is cool, " + storedName;
    }
    
    myButton.onclick = function () {
      setUserName();
    };
    

    分析一下上面的代码:

    前两句,声明了两个变量myButtonmyHeading,分别对buttonh1元素作引用;

    接下来,定义了一个函数setUserName(),该函数用于设置个性化问候语(函数中的prompt()用于获取用户输入,若用户输入为空即重新弹窗;否则使用localStorage浏览器 API 将用户输入的字符串存下来,并将myHeadingtextContent设置为该字符串);

    接下来,是一个if ... else块,是一段初始化代码(首先判断localStorage里是否有设置的信息,没有的话即调用setUserName()函数进行设置,否则直接获取并更新textContent);

    最后,将事件处理器绑定到button上。

本小节的内容跟着一步步走下来,最终看到的页面如下图所示(比对下main.js的源码)。

Website Screenshot Scripted - developer.mozilla.org

7 网站发布

网站代码编写完成后,目的是让人们可以访问。本小节将介绍如何以最简单的方式将样例代码发布到线上。

为了更好的控制网站内容和用户体验,多数人一般会选择购置域名和虚拟主机来实现。

用于创建个人博客或日常练习的话,用 『GitHub Pages』就够了。非常简单,只需要创建一个仓库,上传代码并稍作配置即可。具体可以参阅相关文档。

8 Web 工作机制初探

当我们使用浏览器访问一个网站时,其背后做了什么?本小节会概述 Web 的工作机制。虽然这块内容短期内对我们在编码上没多大帮助,但了解一下 Web 的工作机制,长远来说还是很有用的。

  • 客户端与服务器

连接到 Web 的计算机被称为客户端(Clients)和服务器(Servers)。

客户端为用户的网络连接设备(台式机、笔记本、手机或其它可上网设备)和这些设备上的 Web 访问软件(如 Chrome 或 Firefox 浏览器)。 服务器为存储网页或应用的计算机。当客户使用设备访问一个网页时,该网页会被下载到客户端机器,然后再被 Web 浏览器显示。

  • 其它方面

此外,从客户端到服务器还需要经过如下几个部分,先做一下名词解释:

① 用户本地网络连接

允许用户在网络上发送和接收数据。

② DNS

即域名系统(Domain Name System),域名与 IP 的映射表。浏览器知道域名对应的服务器 IP 才能将消息正确的发送到目的地。

③ TCP/IP

即传输协议和网络协议(Transmission Control Protocol and Internet Protocol),定义了数据如何在网络上传输。

④ HTTP

即超文本传输协议(Hypertext Transfer Protocol),客户端与服务器相互交流的语言。

⑤ 网页文件

一个网站由多种文件组成,主要有代码文件(HTML、CSS 与 JavaScript)和资产文件(图片、视频与文档)。

  • 整体交互顺序概述

当用户在浏览器输入一个网址时,发生的事情依序为:

① 浏览器询问 DNS 服务器,找到网址对应服务器的 IP 地址。

② 浏览器向服务器发送一条 HTTP 请求消息,要求它向客户端发送一份网站副本。此消息以及客户端和服务器之间发送的所有其它数据均通过用户本地网络连接的 TCP/IP 协议发送。

③ 若服务器同意客户端的请求,则会向客户端发送“200 OK”消息,然后将网站的文件以多个数据块的方式连续发送到浏览器。

④ 浏览器接收到全部数据块后,将其组装成一个完整的网页来显示给用户。

  • 网页文件解析顺序概述

当浏览器向服务器发送 HTML 文件请求时,这些 HTML 文件通常会以<link>方式引用外部 CSS 或以<script>方式引用外部 JavaScript 。当浏览器加载页面时,了解这些文件的解析顺序很重要:

① 浏览器解析 HTML 文件,找到所有引用 CSS 和 JavaScript 的<link>元素和<script>元素。

② 根据上一步搜集的 CSS 和 JavaScript 地址,请求对应服务器,获取这些 CSS 文件和 JavaScript 文件。

③ 浏览器将 HTML 解析好后,在内存中生成一个 DOM(Document Object Model,文档对象模型)树;将 CSS 解析好后,在内存中生成一个 CSSOM(CSS Object Model,CSS 对象模型)树;将 JavaScript 解析好后,开始编译并执行。

④ 随着浏览器对 DOM 树的构建、CSSOM 树中样式的应用与 JavaScript 的执行,页面就一步步在屏幕上画出来了。

综上,我们对 Web 网站的开发工具、开发流程、文件结构、组成部分与运行机制有了一个整体和初步的了解。

参考资料

[1] Getting started with the web - Learn web development | MDN

若我的文章对您有帮助,欢迎小额打赏,以支持我更好的写作,Thanks!
微信支付宝