3.1 HTML
HTML(HyperText Markup Language,超文本标记语言)是Internet上网页最主要的表现技术。超文本标记语言的文档制作并不复杂,但功能强大,在本身提供经典的UI标签呈现网页内容的同时,还支持不同数据格式的文件嵌入,这使得HTML在Internet上盛行。最新的HTML 5标准增加了更多的强大呈现功能。
3.1.1 HTML介绍
因为HTML是文本语言,所以可以用任何编辑器对其进行编辑,只需将文件以*.html或*.htm命名即可。HTML的第1个版本由Internet工程工作小组(Internet Engineering Task Force,IETF)发布于1993年6月,当前最常见的4.01版本由W3C(World Wide Web Consortium,万维网联盟)发布于1999年12月,目前不同的操作系统和浏览器都对4.01版本完全支持。最新的HTML 5于2008年1月形成第1份正式草案,该版本对4.01版本有较大改进。目前HTML 5已获得大多数浏览器的支持,但不同的浏览器对一些特性的支持程度并不一致。
HTML的框架格式如下:
HTML语言的特点如下。
• HTML本身由尖括号表达的标签组成,如<html>、<br/>等。
• 一般标签成对出现,如<html></html>、<body> </body>,在成对标签之间放入标签内容。
• 个别标签没有内容时,则可以用单个标签组成,如<br />。注意尖括号等特殊标签一定要写成半角形式,不能是中文全角形式。
• 标签对<!-- -->用于表达注释,注释只在查看HTML代码时出现,在浏览器解析时将不显示其中的内容。
• 标签之间可以嵌套,但不可以交错,例如,下面的代码不正确:
注意:虽然一般标签可以嵌套使用,但不可以在注释标签 中嵌套另外一个注释标签。
• 有些标签有属性字段,在尖括号中通过键值对的方式设置,例如,超链接标签的href属性的设置方法如下:
• 标签本身不区分大小写,例如,可以这样写:
注意:虽然本例语法正确,但建议开发者遵循所有标签都小写的惯用做法。
• 超文本标记语言的文件有一个基本的整体结构:<html>是整个文件的顶层标签,包含文件中的所有内容;<html>的内容由头和实体两部分组成,即<head></head>和<body></body>。头和实体的内容则由网页设计者通过其他HTML标签进行开发。
注意:HTML头与HTTP头是两个完全不同的概念,读者应该注意区分。
• 浏览器一般忽略文件中的回车符,对文件中的空格通常也不按源程序中的效果显示。对于确实需要显示空格和回车符的地方,HTML通过特殊的符号来表达。例如,HTML源文件如下:
在浏览器解析后,很多空格将被忽略,只显示一个空格,如图3.1所示。
图3.1 浏览器解析后会忽略多余的空格
【示例3-1】如果开发者确实希望在浏览器中显示空格,则需用特殊字符“ ”进行表示。例如,把源文件改为:
浏览器的显示效果如图3.2所示。
图3.2 浏览器对特殊字符的显示效果
除“ ”外,HTML还有很多其他特殊字符,常用的如表3.1所示。
表3.1 常用的HTML特殊字符
3.1.2 HTML基本标签
我们已经掌握了HTML的基本语法,本节开始讲解HTML的常用标签,建议读者通过边看书、边实践的方式学习,这样能够快速掌握HTML的基本技巧。
注意:本节只列出了常用标签的普通使用方法,能够帮助读者迅速上手HTML语言。但本书不是HTML的参考手册,关于HTML的全面知识还需读者查阅其他文献。
1. 段落
HTML会忽略源文件中的回车符和换行符,所以需要用特别的标签来表示段落。段落的标签是<p>,比如:
【示例3-2】<hr/>标签表示单行横线显示,<br/>标签表示换行,比如:
上述HTML代码的显示效果如图3.3所示。
图3.3 显示效果
注意:嵌在<head>中的<meta charset="utf-8"/>标签是为了让浏览器以UTF-8方式解析文件内容,以便在不同的操作系统和语言环境中能正常显示汉字。本章的所有带汉字页面中都加入该标签,后续不再重复说明。
2. 标题
HTML有特殊的标签用于显示标题,浏览器会根据显示器的分辨率自动设置标题的字号。标题由大到小分别有6个标签:从<h1>到<h6>。
【示例3-3】如下示例用于比较标题字体和普通字体:
显示效果如图3.4所示。
图3.4 HTML标题字体的显示效果
3. 字体格式
除了标题字体,HTML还允许对显示格式进行更多风格的控制。例如,<b>定义粗体字、<i>定义斜体字、<del>定义删除字等:
显示效果如图3.5所示。
图3.5 HTML字体风格控制的显示效果
HTML还有很多控制显示字体格式的标签,常用的如表3.2所示。
表3.2 常用的字体格式的标签
4. 链接和图像
网页之间的链接是HTML的重要功能,链接功能用<a>标签实现,比如:
上述代码中的<a>标签定义了两个属性,href设置被跳转的URL,target设置在什么窗口中打开链接。
链接除了可以是上述文字(“单击进入百度”),还可以是图片。图片用标签<img>表达,比如:
标签<img>有两个常用的属性:src设置图片文件名,可以是绝对路径或相对路径;alt设置图片显示失败时替换的显示文字。用图片实现超链接的示例代码如下:
5. 表格
HTML中的表格有两种作用:一种是显示真实的表结构及数据,另一种是控制网页布局。两种方式都通过<table>、<tr>、<td>、<th> 4个标签分别声明表格、表行、表单元、表头。显示表结构及数据时通常需要为表格设置边框;而控制网页布局时通常需要用到表格嵌套,即在一个表格的标签<td>中设置另外一个表格。
【示例3-4】表格的示例如下:
表格常用的属性有border、colspan、rowspan等,分别设置边框宽度、跨列单元、跨行单元等。上述示例的显示效果如图3.6所示。
图3.6 HTML表格的显示效果
6. 列表
列表是常用的显示方式,HTML中的列表有以下3种。
• 无序列表:用标签<ul>表示列表,用<li>表示表项。
• 有序列表:用标签<ol>表示列表,用<li>表示表项。
• 定义列表:用标签<dl>表示列表,用<dt>表示被定义词,用<dd>表示定义描述。
【示例3-5】列表的示例如下:
HTML列表的显示效果如图3.7所示。
图3.7 HTML列表的显示效果
7. 颜色及背景
HTML的颜色有3种表达方式:十六进制数字、RGB值或者颜色名称。颜色可以用于设置字体、网页背景等。例如,通过如下3种方式都可以设置页面背景为红色:
8. Flash及音视频播放
除了上述基本页面呈现方式,HTML还支持声音、视频、Flash集成,这才使得当今的网页丰富多彩。可以用<object>标签播放嵌入式Flash,举例如下:
<object>标签中的classid、codebase等属性用于指明客户端播放插件,开发者在使用中无须修改这部分内容,只需修改<embed>标签的相关属性就可以设置不同的Flash文件、播放窗口的大小等。
音频及视频可以通过<audio>及<video>标签嵌入HTML中,浏览器遇到它们时会将本地可用的音频及视频播放器嵌入页面中,比如:
HTML可以识别的音频格式包括*.mid、*.midi、*.rm、*.wav、*.wma、*.mp3等,视频格式包括*.avi、*.wmv、*.mpg、*.mpeg、*.mov、*.rm、*.ram、*.swf、*.flv、*.mp4等。
3.1.3 HTML表单
HTML表单用于从客户端收集用户在浏览器中的输入,是HTML实现客户端与服务器交互的核心方法。作为连接客户端与服务器的纽带,HTML表单也是Python中各Web框架编程都要用到的技术。HTML表单用<form>标签表达,其内容由输入控件和提交控件组成,表单的基本工作方式如下。
• 用户在浏览器中输入数据并提交,输入数据的方式可以是文本、单选、多选等。
• 浏览器将输入的数据封装到HTTP Body中并以POST方式提交给服务器。
• 服务器收到请求后将结果Response给浏览器。
1. 文本输入
HTML表单中的文本输入有单行文本、多行文本、密码框等,分别用标签<input type="text">、<textarea>、<input type="password">表示,示例如下:
需要给每个输入控件设置一个不同的“name”属性,该属性用于在表单被提交到服务器后,使服务器识别各个输入控件。还可以通过设置rows和cols属性控制输入框的大小。
2. 单项选择
单项选择有两种表达方式:单选按钮或者下拉列表,它们分别用标签<input type="radio">、<select>/<option>表达,示例如下:
通过在<input type="radio">中设置check属性可以标识哪一项默认被选择,<option>标签的selected属性有同样的作用。此外,需要给每一个选项设置value属性,该属性用于在服务器端检查哪一个选项被选择,例如,当本例中的“学历”下拉列表被选为“研究生及以上”时,服务器端在检查Post消息体时将可以收到“grade: master”的输入。
3. 多项选择
多项选择用复选框表达,相应的HTML标签是<input type="checkbox">,示例如下:
4. 文件上传
HTML定义了标准的文件上传控件,相应的HTML标签是<input type="file">,示例如下:
标签虽然简单,但在浏览器中的功能十分强大。如图3.8所示,标签提供了一个文件名输入框,并且有一个浏览按钮通过操作系统的文件选择框进行文件选择,通过accept属性可以设置文件选择框中的文件筛选器。
图3.8 HTML文件选择
5. 边框及提交
HTML提供了边框控件,可以将所有其他控件包含在一起,以形成较好的视觉效果,边框控件的标签为<fieldset>。完成前面的所有操作后,只需添加提交按钮控件即可,标签为<submit>。表单的整体结构示例如下:
集成本节学习的所有控件,显示效果如图3.9所示。
图3.9 集成HTML表单控件的显示效果