html5 概述html5 是 html 标准的下一个重要版本,用来替代 html 4.01,xhtml 1.0 以及 xhtml 1.1。html5 也是一种在万维网上构建和呈现内容的标准。
html5 是万维网联盟(w3c)和网页超文本技术工作小组(whatwg)合作的产物。
这一新标准中加入了视频播放和拖放等特性,过去这都依赖于第三方浏览器插件,比如 adobe flash,microsoft silverlight 以及 google gears。
浏览器支持最新版 apple safari,mozilla firefox 和 opera 支持大部分 html5 特性,ie9 也支持一些 html5 的功能。
预装在 iphones,ipads 和 android 手机上的手机浏览器都对 html5 有良好的支持。
新特性html5 引入了许多新元素和属性帮助我们构建现代化的网站。下面是 html5 引入的主要特性:
新的语义化元素: 比如 , 和 。
表单 2.0: 改进了 html web 表单,为 标签引入了一些新的属性。
持久的本地存储: 为了不通过第三方插件实现。
websocket: 用于 web 应用程序的下一代双向通信技术。
服务器推送事件: html5 引入了从 web 服务器到 web 浏览器的事件,也被称作服务器推送事件(sse)。
canvas: 支持用 javascript 以编程的方式进行二维绘图。
音频和视频: 在网页中嵌入音频或视频而无需借助第三方插件。
地理定位: 用户可以选择与我们的网页共享他们的地理位置。
微数据: 允许我们创建 html5 之外的自定义词汇表,以及使用自定义语义扩展网页。
拖放: 把同一网页上的条目从一个位置拖放到另一个位置。
向后兼容html5 被设计为尽可能的对现有浏览器向后兼容。新特性都是建立在现有特性的基础上,并且允许我们为旧浏览器提供备用内容。
建议使用少量的 javascript 代码检测单个 html5 特性的支持度。
html5 语法
html5 有“自己的” html 语法,它与已经发布在网络上的 html 4 以及 xhtml1 文档兼容,但是不兼 html 4 中更复杂的 sgml 特性。
html5 并没有 xhtml 中需要小写标签名,属性要带引号,属性必须有一个值以及必须闭合所有空元素的语法规则。
但是 html5 更具灵活性,支持下列形式:
标签名大写。
属性的双引号可选。
属性值可选。
闭合空元素可选。
doctype
在老版本的 html 中,doctype 很长,因为 html 语言是基于 sgml 的,需要引用一个 dtd。
html5 作者可以使用简单的语法来指定如下形式的 doctype:
xml/html code复制内容到剪贴板
html>
上述语法不区分大小写。
字符编码html5 作者可以使用简单的语法指定字符编码,如下所示:
xml/html code复制内容到剪贴板
上述语法不区分大小写。
xml/html code复制内容到剪贴板
html5 移除了所需的额外信息,我们可以使用如下所示的简单语法:
xml/html code复制内容到剪贴板
标签目前为止我们这样编写 :
xml/html code复制内容到剪贴板
html5 移除了所需的额外信息,我们可以使用如下所示的简单语法:
xml/html code复制内容到剪贴板
html5 元素html5 元素使用起始标签和结束标签标记。标签使用尖括号之间的标签名限定。
起始标签和结束标签的区别在于后者标签名前面包含一个斜杠。
下面是一个 html5 元素示例:
xml/html code复制内容到剪贴板
...
html5 标签名不区分大小写,可以全部大写或者混合使用,虽然最常见的约定是始终使用小写。
大多数元素都包含一些内容,比如
...
包含一个段落。但是,有些元素不能包含任意内容,它们被称作空白元素。比如,br,hr,link 和 meta 等等。html5 文档为了得到更好的结构,引入了下面的标签:
section: 这个标签表示一个通用的文档或者应用程序节。它可以和 h1-h6 一起使用来表示文档结构。
article: 这个标签表示文档内容的一个独立块,比如博客条目或者报纸上的文章。
aside: 这个标签表示与页面其他部分略微相关的内容块。
header: 这个标签表示一个节的头部。
footer: 这个标签表示一个节的脚注,可以包含作者,版权等信息。
nav: 这个标签表示用于导航文档的节。
dialog: 这个标签可以用于标记会话。
figure: 这个标签可以用于关联标题和某些嵌入内容,比如图表和视频。
一个 html5 文档的标记看起来就像下面这样:
xml/html code复制内容到剪贴板
html>
......
...
...
...
...