第3章 网页的基石——HTML与CSS基础

学习指引

HTML也叫作超文本标记语言,它是网页设计的基础,也是网站开发者必须熟练掌握的一门标记语言。本章将讲解HTML的基础知识。

重点导读

• 掌握HTML文档的基本结构。

• 了解HTML的常见元素。

• 了解CSS语法。

3.1 HTML简介

前端即网站前台部分,指运行在PC端、移动端等浏览器上展现给用户浏览的网页。随着互联网技术的发展,HTML 5、CSS 3、前端框架的应用,跨平台响应式网页设计已经能够适应各种屏幕分辨率,完美的动效设计,给用户带来极高的用户体验。

HTML是前端开发人员的必备技能,也是所有程序开发人员都常用到的工具。HTML是指超文本标记语言(Hyper Text Markup Language),是标准通用标记语言下的一个应用。“超文本”就是指页面内可以包含图片、链接,甚至音乐、程序等非文字元素。超文本标记语言的结构包括“头”部分和“主体”部分,其中,“头”部分提供关于网页的信息,“主体”部分提供网页的具体内容。

3.1.1 HTML元素和属性

1. HTML元素

HTML元素指从开始标签到结束标签的所有代码,如表3-1所示。

表3-1 HTML元素实例

2. HTML元素语法

(1)HTML元素通常以开始标签起始,以结束标签终止。

(2)元素的内容是开始标签与结束标签之间的内容。

(3)有些HTML元素具有空内容,空元素在标签中关闭(以开始标签的结束而结束)。

(4)大多数HTML元素可设置属性。

3. 嵌套HTML元素

大多数HTML元素可以嵌套其他HTML元素。

HTML文档由嵌套的HTML元素构成。

HTML文档实例:

上面这段HTML代码包含三个嵌套的HTML元素,分别如下。

1)<p>元素

     <p>Hello World!</p>

这个<p>元素定义了HTML文档中的一个段落。

这个元素拥有一个开始标签<p>,以及一个结束标签</p>。

元素内容是:Hello World!。

2)<body>元素

<body>元素定义了HTML文档的主体。

这个元素拥有一个开始标签<body>,以及一个结束标签</body>。

元素内容是另一个HTML元素(<p>元素)。

3)<html>元素

     <html>
     <body>
     <p> Hello World!</p>
     </body>
     </html>

<html>元素定义了整个HTML文档。

这个元素拥有一个开始标签<html>,以及一个结束标签</html>。

元素内容是另一个HTML元素(<body>元素)。

3.1.2 HTML样式

样式是HTML 4引入的,它是一种新的首选的改变HTML元素样式的方式。通过HTML样式,能够通过使用style属性直接将样式添加到HTML元素,或者间接地在独立的样式表中(CSS文件)进行定义。

【例3-1】HTML样式实例–字体样式。

运行结果:style样式中指定了font-family、color、font-size三种样式,运行结果如图3-1所示。

图3-1 HTML样式实例–字体样式

【例3-2】HTML样式实例–背景颜色。

运行结果:style样式实例分别为<body>、<h2>、<p>指定了background-color样式,设置其背景颜色依次为:灰色、红色、黄色,运行结果如图3-2所示。

图3-2 HTML样式实例–背景颜色

【例3-3】HTML样式实例–文本对齐。

运行结果:style样式分别为<h1>、<p>指定了text-align样式,设置其文本对齐方式均为居中对齐,运行结果如图3-3所示。

图3-3 HTML样式实例–文本对齐

3.1.3 超链接

HTML使用超链接与网络上的另一个文档相连。几乎可以在所有的网页中找到链接。单击链接可以从一个页面跳转到另一个页面。

超链接可以是一个字,一个词,或者一组词,也可以是一张图片,单击这些内容可以跳转到新的文档或者当前文档中的某个部分。

可以使用<a>标签在HTML中创建超链接,使用<a>标签的方式有以下两种。

(1)通过使用href属性创建指向另一个文档的链接。

(2)通过使用name属性创建文档内的书签。

超链接的HTML代码很简单,通常以如下方式创建超链接。

     <a href="url">超链接文本</a>

href属性规定链接的目标,开始标签和结束标签之间的文字被作为超级链接来显示。

【例3-4】超链接实例。

运行结果如图3-4所示,单击Hello World!即可进入超链接指向的页面。

图3-4 超链接实例

3.1.4 图像标签

在HTML中,图像由<img>标签定义。

<img>是空标签,意思是说,它只包含属性,并且没有闭合标签。

要在页面上显示图像,需要使用源属性(src)。

src即source。源属性的值是图像的URL地址。

定义图像的语法是:

     <img src="url" />

URL指存储图像的位置,可以是相对位置,也可以是绝对位置。

浏览器将图像显示在文档中图像标签出现的地方。如果将图像标签置于两个段落之间,那么浏览器会首先显示第一个段落,然后显示图片,最后显示第二段。

     替换文本属性(alt)

alt属性用来为图像定义一串预备的可替换的文本。替换文本属性的值是用户定义的。

     <img src="url" alt="text">

在浏览器无法载入图像时,替换文本属性可以告诉读者丢失的信息。此时,浏览器将显示这个替代性的文本而不是图像。为页面上的图像都加上替换文本属性是一个好习惯,这样有助于更好地显示信息,并且对于那些使用纯文本浏览器的人来说是非常有用的。

【例3-5】图像标签实例。

运行结果如图3-5所示。

图3-5 图像标签实例

3.1.5 HTML表格

表格由<table>标签来定义。每个表格均有若干行(由<tr>标签定义),每行被分割为若干单元格(由<td>标签定义)。字母td指表格数据(table data),即数据单元格的内容。数据单元格可以包含文本、图片、列表、段落、表单、水平线、表格等。

【例3-6】表格实例。

运行结果:在浏览器中的显示如图3-6所示。

图3-6 表格实例

1. 边框属性

如果不定义边框属性,表格将不显示边框。有时这很有用,但是大多数时候,我们希望显示边框。

使用边框属性来显示一个带有边框的表格:

2. 表格的表头

表格的表头使用<th>标签进行定义。

大多数浏览器会把表头显示为粗体居中的文本。

【例3-7】表头实例。

运行结果:在浏览器中的显示如图3-7所示。

图3-7 表头实例

3.1.6 HTML头部元素

1. HTML <head>元素

<head>元素是所有头部元素的容器。<head>内的元素可包含脚本,指示浏览器在何处可以找到样式表,以及提供元信息等。

以下标签都可以添加到head部分:<title>、<base>、<link>、<meta>、<script>、<style>。

2. HTML <title>元素

<title>标签定义文档的标题。

title元素能够定义浏览器工具栏中的标题,提供页面被添加到收藏夹时显示的标题,显示在搜索引擎结果中的页面标题。

一个简化的HTML文档如下。

3. HTML <base>元素

<base>标签为页面上的所有链接规定默认地址或默认目标(target)。

4. HTML <link>元素

<link>标签定义文档与外部资源之间的关系,最常用于连接样式表(CSS)。

5. HTML <style>元素

<style>标签用于为HTML文档定义样式信息,可以在style元素内规定HTML元素在浏览器中呈现的样式。

6. HTML <meta>元素

元数据(metadata)是关于数据的信息。

<meta>标签提供关于HTML文档的元数据。元数据不会显示在页面上,但是对于机器是可读的。

典型的情况是,meta元素被用于规定页面的描述、关键词、文档的作者、最后修改时间以及其他元数据。

<meta>标签始终位于head元素中。

元数据可用于浏览器(如何显示内容或重新加载页面)、搜索引擎(关键词),或其他Web服务。

一些搜索引擎会利用meta元素的name和content属性来索引页面。

下面的meta元素定义页面的描述。

     <meta name="description" content="百度一下,你就知道" />

下面的meta元素定义页面的关键词。

     <meta name="keywords" content="HTML, CSS " />

name和content属性的作用是描述页面的内容。

7. HTML <script>元素

<script>标签用于定义客户端脚本,如JavaScript。

3.1.7 表单

在HTML中表单用于收集用户输入信息。

<form>元素定义HTML表单:

     <form>
     表单元素
     </form>

表单元素指的是不同类型的input元素、复选框、单选按钮、提交按钮等。

<input>元素是最重要的表单元素。

<input>元素有很多形态,可以根据不同的type属性改变。

<input>元素的常用类型如表3-2所示。

表3-2 <input>元素的常用类型

【例3-8】input元素常用类型实例。

<input type="text">定义用于文本输入的单行输入字段。

运行结果:实例中用到text、radio、submit、reset类型,运行结果如图3-8所示。

图3-8 input元素常用类型实例

1. action属性

action属性定义在提交表单时执行的动作,通常表单会被提交到Web服务器上的网页。

例如:<form action="action_page.jsp">

如果省略action属性,则action会被设置为当前页面。

2. method属性

method属性规定在提交表单时所用的HTTP方法(GET或POST)。

     <form action="action_page.jsp" method="GET">

或:

     <form action="action_page.jsp" method="POST">

1)GET方法(默认方法)

使用GET方法时,表单数据在页面地址栏中是可见的。

     action_page.jsp?name=Name&tel=Tel

GET最适合少量数据的提交。浏览器会设定容量限制。

2)POST方法

如果表单正在更新数据,或者包含敏感信息(例如密码),POST的安全性更佳,因为在页面地址栏中被提交的数据是不可见的。

3. name属性

要正确地提交数据,每个输入字段必须设置一个name属性。

如以下代码只会提交姓名字段。

4. form属性

HTML <form>元素,若设置所有可能的属性,是这样的:

     <form action="action_page.jsp" method="GET" target="_blank" accept-charset="UTF-8"
     ectype="application/x-www-form-urlencoded" autocomplete="off" novalidate>
     表单元素
     </form>

<form>的属性及描述如表3-3所示。

表3-3 <form>的属性及描述

3.1.8 HTML事件

本节以表格形式列出HTML常用事件,但不做演示,读者可自行学习。

1. Window事件属性

针对Window对象触发的事件(应用到<body>标签),如表3-4所示。

表3-4 Window事件属性

2. Form事件

由HTML表单内的动作触发的事件(应用到几乎所有HTML元素,但最常用在form元素中),如表3-5所示。

表3-5 Form事件属性

3. Mouse事件

由鼠标或类似用户动作触发的事件,如表3-6所示。

表3-6 Mouse事件属性

4. Keyboard事件

由键盘或类似用户动作触发的事件,如表3-7所示。

表3-7 Keyboard事件属性

3.2 CSS简介

层叠样式表(Cascading Style Sheets,CSS)是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。

在CSS还没有引入到页面设计之前,传统的HTML要实现页面美化在设计上是十分麻烦的,例如要设计页面中文字的样式,如果使用传统的HTML语句来设计页面就不得不在每个需要设计的文字上都定义样式。CSS的出现改变了这一传统模式。

3.2.1 CSS语法

CSS语法由两个主要的部分构成:选择器,以及一条或多条声明。例如:

     selector {declaration1; declaration2;…;declarationN }

所有HTML中的标记都是通过不同的CSS选择器进行控制的。

每条声明由一个属性和一个值组成。

属性(property)是希望设置的样式属性(style attribute)。每个属性有一个值,属性和值之间用冒号分开。

     selector {property: value}

例如:

其中,background是属性,red是background属性的一个值。

3.2.2 CSS选择器

常用的CSS选择器有标签选择器,类选择器,id选择器等。使用选择器可以对不同的HTML元素进行样式控制,实现样式效果。

1. 标签选择器

最常见的CSS选择器是标签选择器,文档的元素就是最基本的选择器。如果设置HTML的样式,选择器通常是某个HTML标签,如p、h1、em、a,甚至可以是html本身。

例如:

2. 类选择器

标签选择器在使用中非常简捷,但是会有一定的局限性,如果声明了标签选择器,页面中所有该标签都会应用该样式。假如页面中有三个<span>标签,如果想让每个显示效果都不一样,使用标签选择器就无法实现了。

类选择器允许以一种独立于文档元素的方式来指定样式。类选择器的名称由用户自己定义,以“.”开头,在HTML页面中使用自己定义的class属性声明即可。

只有适当地使用class属性标记文档后,才能使用类选择器,所以使用这两种选择器通常需要先做一些构想和计划。

例如:

以下是<body>中<span>标签的定义方法:

     <span class="one">一</span>
     <span class="two">二</span>
     <span class="three">三</span>
3. id选择器

id选择器通过HTML元素的id属性来选择增添样式,与类选择器使用方法类似。但是HTML页面中不能包含两个相同的id标记,因此定义的id选择器只能被使用一次。

id选择器以“#”号开始,在HTML页面中使用自己定义的id属性声明即可。

例如:

以下是<body>中<span>标签的定义方法。

     <span class=" span_text " id=" one">一</span>
     <span class=" span_text " id=" two">二</span>
     <span class=" span_text " id= " three ">三</span>

3.3 综合案例

利用本章学习的HTML与CSS基础知识,以及简单的JavaScript语句,完成对输入信息的收集与展示。

【例3-9】HTML基础综合案例。

运行结果如图3-9和图3-10所示。

图3-9 页面显示效果

图3-10 提交信息后页面弹出对话框

3.4 就业面试解析与技巧

本章所讲的都是HTML与CSS基础知识,在前端开发的就业面试中,这些是远远不够的,读者还需要更深入地学习掌握JavaScript、jQuery等知识。

3.4.1 面试解析与技巧(一)

面试官:行内元素有哪些?块级元素有哪些?空元素有哪些?

应聘者:

行内元素:a、b、span、img、input、strong、select、label、em、button、textarea。

块级元素:div、ul、li、dl、dt、dd、p、h1~h6、blockquote。

空元素:即没有内容的HTML元素,例如,br、meta、hr、link、input、img。

3.4.2 面试解析与技巧(二)

面试官:简述src与href的区别。

应聘者:

href是指向网络资源所在位置,建立和当前元素(锚点)或当前文档(链接)之间的链接,用于超链接。

src是指向外部资源的位置,指向的内容将会嵌入到文档中当前标签所在位置;在请求src资源时会将其指向的资源下载并应用到文档内,例如,JS脚本,图片和框架等元素。当浏览器解析到该元素时,会暂停其他资源的下载和处理,直到将该资源加载、编译、执行完毕,图片和框架等元素也如此,类似于将所指向资源嵌入当前标签内。这也是为什么将JS脚本放在底部而不是头部的原因。