本页使用了标题或全文手工转换

HTML5

维基百科,自由的百科全书
跳转至: 导航搜索
HTML5
HyperText Markup Language
HTML5 logo and wordmark.svg
扩展名 .html
互联网媒体类型 text/html
类型代码英语Type code TEXT
统一类型标识英语Uniform Type Identifier index.html[1]
开发者 万维网联盟WHATWG
初始版本 2014年10月28日
(2年前)
​(2014-10-28[2]
格式类型 置标语言
延伸成 XHTML5(XML-serialized HTML5)
标准 WHATWG HTML
自由格式
XHTML5
扩展名 .xhtml, .html
互联网媒体类型 application/xml, application/xhtml+xml
开发者 万维网联盟WHATWG
格式类型 置标语言
延伸自 XML、HTML5
自由格式

HTML5[a]HTML最新的修订版本,2014年10月由万维网联盟(W3C)完成标准制定[2][4]。目标是取代1999年所制定的HTML 4.01和XHTML 1.0标准,以期能在互联网应用迅速发展的时候,使网络标准达到匹配当代的网络需求。广义论及HTML5时,实际指的是包括HTML、CSSJavaScript在内的一套技术组合。它希望能够减少网页浏览器对于需要插件丰富性网络应用服务(Plug-in-Based Rich Internet Application,RIA),例如:AdobeFlashMicrosoft SilverlightOracle JavaFX的需求,并且提供更多能有效加强网络应用的标准集。

HTML5添加了许多新的语法特征,其中包括<video><audio><canvas>元素,同时集成了SVG内容。这些元素是为了更容易的在网页中添加和处理多媒体和图片内容而添加的。其它新的元素如<section><article><header><nav>则是为了丰富文档的数据内容。新的属性的添加也是为了同样的目的。同时也有一些属性和元素被移除掉了。一些元素,像<a><cite><menu>被修改,重新定义或标准化了。

同时APIs和DOM已经成为HTML5中的基础部分了[5]。HTML5还定义了处理非法文档的具体细节,使得所有浏览器和客户端程序能够一致地处理语法错误[6]

发展历史[编辑]

网页超文本技术工作小组(WHATWG)于2004年开始制定新标准。在当时,HTML 4.01自2000年来没有更新[7],以及万维网联盟(W3C)正在将未来的发展重点放在XHTML 2.0。2009年,W3C允许XHTML 2.0工作组章程结束过期并且决定不再续订[8]。W3C与WHATWG合作共同为发展HTML5而努力[8]

2004年6月,Mozilla基金会Opera软件公司在万维网联盟(W3C)所主办的研讨会上提出了一份立场文件[9],其重点是开发与现有浏览器向后兼容的技术[10],包括Web Forms 2.0最初草案规范。研讨会最后以——8票赞成,14票反对——否决继续对HTML的开发工作[11]。这引起一些人的不满,在研讨会之后,网页超文本技术工作小组(WHATWG)立即成立,继续该份立场文件的开发工作,第二个草案,Web Applications 1.0也公布了[12]。后来这两种规范合并形成HTML5[13]。2007年,获得W3C接纳,并成立了新的HTML工作团队。2008年1月22日,第一份公开工作草案发布[14]

尽管HTML5已经在网络开发人员中非常出名了,但是它成为主流媒体的一个话题是在2010年的4月[15][16][17][18],当时苹果公司的CEO乔布斯发表一篇题为“对Flash的思考”的文章,指出随着HTML5的发展,观看视频或其它内容时,Adobe Flash将不再是必须的[19]。这引发了开发人员间的争论,包括HTML5虽然提供了加强的功能,但开发人员必须考虑到不同浏览器对标准不同部分的支持程度的不同,以及HTML5和Flash间的功能差异[20]

2014年10月28日,W3C正式发布HTML 5.0推荐标准[21]

时间表[编辑]

HTML5.0,HTML5.1和HTML5.2的合并时间表:

2012年 2013年 2014年 2015年 2016年 2017年 2018年
HTML 5.0 候选版 征求评价 推荐标准
HTML 5.1 第一工作草案 最后召集 候选版 推荐标准
HTML 5.2[22] 第一工作草案 候选版 推荐标准
HTML 5.3[23] 编者草案

特点[编辑]

标记[编辑]

HTML5提供了一些新的元素和属性,反映典型的现代用法网站。其中有些是技术上类似<div><span>标签,但有一定含义,例如<nav>(网站导航块)和<footer>。这种标签将有利于搜索引擎的索引整理、小显示屏设备和视障人士使用。同时为其他浏览要素提供了新的功能,通过一个标准接口,如<audio><video>标记[24][25][26]。一些过时的HTML 4.01标记将取消,其中包括纯粹用作显示效果的标记,如<font><center>,因为它们已经被CSS取代[27]。还有一些通过DOM的网络行为。

尽管和SGML在标记上的相似性,HTML5的句法并不再基于它了[28][29],而是被设计成向后兼容对老版本的HTML的解析。它有一个新的开始列看起来就像SGML的文档类型声明,<!DOCTYPE HTML>,这会触发和标准兼容的渲染模式[30]。在2009年1月5日,HTML5添加了Web Form 2.0的内容,HTML5开始发展起来[31][32]

新的API[编辑]

HTML5相关APIs[33]

除了原先的DOM接口,HTML5增加了更多样化的应用程序接口(API)[34]

以上技术尽管是WHATWG HTML说明文档的内容,但并没有全部包括在W3C HTML5的说明文档里[46]。一些相关的技术,像下面所列的,并没有包括在这2份文档中的任何一份中。W3C给这些技术单独出版了说明文档。

  • 地理位置
  • 网页SQL数据库 ─ 本地SQL数据库(不再维护)[47]
  • IndexedDB[48]
  • 文件[49] ─ 处理文件上传和操纵文件[50]
  • 目录和文件系统 ─ 这个API是为了满足客户端在没有好的数据库支持情况下存储要求[51]
  • 文件写入 ─ 从网络应用程序向文件里写内容[52]
  • 网络音频[53]
  • ClassList[54]
  • 网络加密[55]
  • WebRTC[56]

一个普遍的误解是HTML5能够在网页中提供动画效果,这是不对的,动画效果是需要配合JavaScriptCSS。然而静态HTML5配合CSS可以表示出覆杂的排版结构而且原生支持与视频的混合与控制(控制一般由JavaScript运行),因此简单可以把HTML5单位时间的状态理解为动画的关键帧

XHTML5(XML-serialized HTML5)[编辑]

XHTML5是对HTML5的XML序列化。XML文档必须被设置为XML互联网文件类型,像application/xhtml+xml或者application/xml。XHTML5要求像XML一样严格的格式化的语法。在XHTML5中,HTML5的<!DOCTYPE HTML>可有可无的。

异常处理[编辑]

HTML5在设计时保证旧的浏览器能够安全地忽略掉新的HTML5代码[5]。与HTML4.01相比,HTML5给出了解析的完整规则,让不同的浏览器即使在发生语法错误时也能返回完全相同的结果[57]

流行度[编辑]

根据2011年9月30日发布的一份报告,全球排名前100的网站中有34个网站都使用了HTML5──主要是搜索引擎社交网站[58]。2013年8月发布的另一份报告显示,财富美国500强企业中已有多达153家采用HTML5[59]

HTML 4.01和XHTML 1.x的差异[编辑]

以下为大略的不同之处,与例子:

  • 文件类型声明(<!DOCTYPE>)仅有一型:<!DOCTYPE HTML>
  • 新的解析顺序:不再基于SGML
  • 新的元素:section, video, progress, nav, meter, time, aside, canvas, command, datalist, details, embed, figcaption, figure, footer, header, hgroup, keygen, mark, output, rp, rt, ruby, source, summary, wbr
  • input元素的新类型:date, email, url等等。
  • 新的属性:ping(用于aarea), charset(用于meta), async(用于script)。
  • 全域属性:id, tabindex, repeat
  • 新的全域属性:contenteditable, contextmenu, draggable, dropzone, hidden, spellcheck
  • 移除元素:acronym, applet, basefont, big, center, dir, font, frame, frameset, isindex, noframes, strike, tt

各浏览器的支持[编辑]

HTML5 Test网站,是用以测试对浏览器对热门新功能的支持。测试的满分是555分,而当中的额外分数表示浏览器对一些没有列入W3C的标准亦有支持,例如<video>元素并没有指明编码标准,HTML5支持MPEG-4、H.264、Ogg Theora及WebM 影音编码。HTML5 Test并未测试所有新加入的功能,分数高只代表浏览器现时对所挑选的新网页编码整体上有较佳的支持,并不代表日后其表现的趋势,因此分数只能作为参考。

截止2016年8月6日,五大浏览器最新版本所获取的分数分别是[60]

浏览器 正式版本 分数 其他版本 分数
Google Chrome 58 518 57 519
Opera 45 518 37 489
Microsoft Edge 15 473 16 478
Mozilla Firefox 53 474 52 474
Apple Safari 10.1 406 10.2 419

注释[编辑]

  1. ^ 在W3C推荐标准,名称“HTML”和“5”之间没有空格[3]

参考文献[编辑]

  1. ^ Mac Developer Library: System-Declared Uniform Type Identifiers. Apple. 2009-11-17. 
  2. ^ 2.0 2.1 HTML5 specification finalized, squabbling over specs continues. Ars Technica. 2014-10-29 [2014-10-29]. 
  3. ^ A vocabulary and associated APIs for HTML and XHTML. 28 October 2014. 
  4. ^ HTML5 is a W3C recommendation. W3C Blog. 2014-10-28 [2014-10-28]. 
  5. ^ 5.0 5.1 HTML5 differences from HTML4. W3C. 2010-10-19 [2010-12-04]. 
  6. ^ 1.9.2 Syntax Errors. HTML5. 2010-11-16 [2010-12-04]. 
  7. ^ HTML 4 Errata. World Wide Web Consortium. [2010-12-04]. 
  8. ^ 8.0 8.1 Frequently Asked Questions (FAQ) About the Future of XHTML. World Wide Web Consortium. [2010-12-04]. 
  9. ^ Position Paper for the W3C Workshop on Web Applications and Compound Documents. World Wide Web Consortium. [2011-12-30]. 
  10. ^ W3C Workshop on Web Applications and Compound Documents (Day 1) 2004-06-01. World Wide Web Consortium. [2011-12-30]. 
  11. ^ W3C Workshop on Web Applications and Compound Documents (Day 2) 2004-06-02. World Wide Web Consortium. [2011-12-30]. 
  12. ^ [whatwg] WHAT open mailing list announcement. lists.w3.org Mailing Lists. [2015-12-08]. 
  13. ^ This Week in HTML 5 – Episode 5. WHATWG Blog. [2011-12-30]. 
  14. ^ HTML5: A vocabulary and associated APIs for HTML and XHTML.. World Wide Web Consortium. [2009-01-28]. 
  15. ^ FOX News: No Flash on the iPhone? Apple's Steve Jobs Finally Explains Why. Fox News. 2010-04-29. 
  16. ^ TIME: Steve Jobs: ‘Flash is No Longer Necessary’ and Other Musings. Time. 2010-04-29. 
  17. ^ Steve Jobs: Why Apple Banned Flash. CBS News. 
  18. ^ FastCompany: Steve Jobs: Adobe's Flash Is Old PC History, Open Web Is the Future. 
  19. ^ 'Thoughts on Flash', by Steve Jobs, CEO of Apple, Inc. Apple.com. [2014-01-08]. 
  20. ^ Is HTML5 Replacing Flash?. Lyquix.com. [2014-01-08]. 
  21. ^ Open Web Platform Milestone Achieved with HTML5 Recommendation. W3C. 2014-04-28 [2014-10-29]. 
  22. ^ Plan 2014. World Wide Web Consortium. [23 September 2012]. 
  23. ^ Editor’s Draft. World Wide Web Consortium. [6 September 2017]. 
  24. ^ Introduction to HTML5 video
  25. ^ IBM Developer Works New elements in HTML5: Structure and semantics
  26. ^ ICAMD.org Finalcut Silverlight Films that Videographers share Quicktime in a Flash : Video on the Web using HTML5 and other Codecs
  27. ^ 11 Obsolete features — HTML5. W3C. [2014-03-11]. 
  28. ^ HTML5 DTD: "HTML5 is not SGML-based, and there will be no official DTD for it."
  29. ^ HTML 5 Reference: "Although it is inspired by its SGML origins, in practice, it really only shares minor syntactic similarities." "As HTML5 is no longer formally based upon SGML, the DOCTYPE no longer serves this purpose, and thus no longer needs to refer to a DTD."
  30. ^ Shannon Suetos. HTML5: Worth the Hype?. instantshift.com. 26 April 2010 [2012-10-21]. 
  31. ^ Web Forms 2.0. 2009-01-05 [2014-02-11].  obsolescence notice
  32. ^ HTML. whatwg.org. 
  33. ^ Sergey Mavrody "Sergey's HTML5 & CSS3 Quick Reference. 2nd Edition". Belisso Corp., 2012. ISBN 978-0-9833867-2-8
  34. ^ "HTML5 Differences from HTML4 – APIs". World Wide Web Consortium.
  35. ^ "Get Started with HTML5 Canvas". Syntaxxx.
  36. ^ HTML. whatwg.org. 
  37. ^ "Offline Web Applications". World Wide Web Consortium.
  38. ^ HTML. whatwg.org. 
  39. ^ HTML. whatwg.org. 
  40. ^ HTML elements, HTML5. w3.org. (原始内容存档于2014-12-21). 
  41. ^ HTML. whatwg.org. 
  42. ^ HTML. whatwg.org. 
  43. ^ HTML. whatwg.org. 
  44. ^ "HTML5 Web Messaging". World Wide Web Consortium.
  45. ^ "Web Storage Specification". World Wide Web Consortium.
  46. ^ href. 1 Introduction — HTML Standard. Whatwg.org. [2014-01-08]. 
  47. ^ "Web SQL Database". World Wide Web Consortium.
  48. ^ "Indexed Database". World Wide Web Consortium.
  49. ^ File API. W3.org. [2014-01-08]. 
  50. ^ "File API". World Wide Web Consortium.
  51. ^ "Filesystem API". World Wide Web Consortium.
  52. ^ "File API: Writer". World Wide Web Consortium.
  53. ^ Web Audio API. Dvcs.w3.org. [2014-01-08]. 
  54. ^ MDN. element.classList. 
  55. ^ Web Cryptography Candidate Recommendation: https://www.w3.org/TR/WebCryptoAPI/
  56. ^ WebRTC Working Draft: https://www.w3.org/TR/webrtc/
  57. ^ FAQ – WHATWG Wiki. WHATWG. [2011-08-26]. 
  58. ^ Percentage of Web sites Using HTML5. binvisions. [21 October 2011]. 
  59. ^ "HTML5 Popularity Among Fortune 500 Companies". INCORE. Retrieved 5 March 2013.
  60. ^ HTML5 Test官方测试数据

外部链接[编辑]