4月17日,在由InfoQ独家社区支持的上海“拥抱HTML5”活动上,第一次来到中国的《JavaScript DOM编程艺术》和《HTML5 For Web Designer》作者Jeremy Keith与大家一起回顾了HTML的发展历程,分享了HTML5的设计原则,并与在场与会者做了精彩互动。

\

首先,Jeremy回顾了HTML的历史,从HTML 2.0到XHTML 2.0,此处他引用了Postel法则(鲁棒性原则):

\

对自己发送的东西要严格,对接收的东西则要宽容。

\

指出XHTML 2.0由于语法解析过于严格,因此不太适合于Web。

\

Jeremy认为所有的项目都应该有设计原则,HTML5也同样如此,W3C就为此发布了HTML设计原则,他强调了其中的兼容性、实用性与互操作性。

\

1、避免不必要的复杂性

\

Jeremy举了DOCTYPE的例子,表示HTML 4.01和XHTML中的DOCTYPE过于冗长,连自己都记不住这些内容,但在HTML5中只需要简单的\u0026lt;!DOCTYPE html\u0026gt;就可以了。DOCTYPE是给验证器用的,而非浏览器,浏览器只在做DOCTYPE切换时关注这个标签,因此并不需要写得太复杂。然后,他又提到如何指定字符集,在HTML5中只需要\u0026lt;meta charset=\"utf-8\"\u0026gt;。

\

规范也许会写得十分复杂,但浏览器的实现却可能很简单,规范有时会去迁就浏览器的实现。

\

2、支持已有内容

\

XHTML 2.0最大的问题就是不支持已经存在的内容,这违反了Postel法则。现实情况中,开发者可以写出各种风格的HTML,浏览器遇到这些代码时,在内部所构建出的结构应该是一样的,呈现的效果也应该是一样的。

\

3、解决实际问题

\

规范应该去解决现实中实际遇到的问题,而不该考虑那些复杂的理论问题。例如,既然有在\u0026lt;a\u0026gt;中嵌套多个段落标签的需要,那就让规范支持它。

\

4、用户怎么使用的,就怎么设计规范

\

当一个实践已经被广泛接受时,就应该考虑将它吸纳进来,而不是禁止它或搞一个新的实践出来。

\

例如,HTML5中新增了nav、section、article及aside标签,它们引入了新的文档模型,即文档中的文档。在section中,还可以嵌套h1到h6的标签,这样就有了无限的标题层级,这也是很早之前Tim Berners Lee所设想的。

\

5、优雅地降级

\

Jeremy在此处举了input的例子,HTML5中input标签的type属性增加了很多类型,当浏览器不支持这些类型时,默认会将其视为text。这就是一种优雅降级。

\

此外,在谈到HTML5与Flash之争时,他认为很多情况下,这就是\u0026lt;video\u0026gt;和\u0026lt;object\u0026gt;的问题,完全没有必要二者选其一。可以先使用\u0026lt;video\u0026gt;,当浏览器不支持时降级到\u0026lt;object\u0026gt;,反之亦然。如果浏览器对两者都不支持,再降级到\u0026lt;a\u0026gt;,提供一个链接。

\

6、支持的优先级

\

在考虑优先级时,应该按照这个顺序:

\

用户 \u0026gt; 编写HTML的开发者 \u0026gt; 浏览器厂商 \u0026gt; 规范制定者 \u0026gt; 理论

\

用户与开发者的重要性要远远高于规范和理论。

\

在最后的问答环节中,有人提到了HTML5的语法过于灵活,会造成一定的滥用,Jeremy表示赞同,并推荐使用类似JavaScript Lint的工具来帮助编写更好的代码。

\

此外,有人担心\u0026lt;video\u0026gt;外观的可定制性不强,控件不美观,可能会重蹈\u0026lt;select\u0026gt;的覆辙。Jeremy当场演示了一个通过CSS定制样式的\u0026lt;video\u0026gt;,并表示如果不喜欢浏览器提供的控件,完全可以实现自己的控件。

\

HTML5已不再遥远,不必等到规范成熟后才去使用,各个主流浏览器均已纷纷支持HTML5中的一些特性,大家可以从现在开始,拥抱HTML5。您又是怎么看待HTML5的呢?

Jeremy Keith谈HTML5设计原则相关推荐

  1. F#创建者Don Syme谈F#设计原则

    在.Net Fringe 2016大会上,F#创建者Don Syme谈了他对F#现状的看法以及F#的二元性.F#是以一个为面向对象语言构建的运行时为基础构建的函数式语言. \\ F#是2010年发布的 ...

  2. HTML5的学习资料(开发设计原则)

    "Be conservative in what you send; be liberal in what you accept.   –The Robustness principle&q ...

  3. 常见软件设计原则总结

    ​1 Dont' repeate yourself(DRY) DRY是一个最简单的法则,也是最容易被理解的,但有可能是最难被应用的(这需要我们在泛型设计上做相当大的努力,这不是一件容易的事).它意味着 ...

  4. 【六大设计原则-SOLID】

    SOLID简介: 历史:由Robert C·Martin汇总并推广 目标: 使软件更容易被改动 是软件更容易被理解 构建可以在多个软件系统中复用的组件 组成: 名称 简写 含义 单一职责原则 SRP ...

  5. HTML5设计原理-------Jeremy Keith在 Fronteers 2010 上的主题演讲

    本文来源:http://archive.cnblogs.com/a/2012810/ 今天我想跟大家谈一谈HTML5的设计.主要分两个方面:一方面,当然了,就是HTML5.我可以站在这儿只讲HTML5 ...

  6. HTML5设计原理 Jeremy Keith在 Fronteers 2010 上的主题演讲

    今天我想跟大家谈一谈HTML5的设计.主要分两个方面:一方面,当然了,就是HTML5.我可以站在这儿只讲HTML5,但我并不打算这样做,因为如果你想了解HTML5的话,你可以Google,可以看书,甚 ...

  7. php 如何设计索引_Mysql学习浅谈mysql的索引设计原则以及常见索引的区别

    <Mysql学习浅谈mysql的索引设计原则以及常见索引的区别>要点: 本文介绍了Mysql学习浅谈mysql的索引设计原则以及常见索引的区别,希望对您有用.如果有疑问,可以联系我们. 索 ...

  8. [Vue][面试]谈一谈对vue的设计原则的理解

    谈一谈对vue的设计原则的理解 思路: 在vue官网上写着大大的定义和特点: -渐进式JavaScript框架 -易用.灵活和高效 渐进式JavaScript框架: 与其它大型框架不同的是,Vue被设 ...

  9. 从设计原则谈软件开发(二)

    最近一直在一个培训公司做着极为无聊的培训,所以一直都没有时间上网.今天突然发现这里可以上无线,嘿嘿,就上来继续把这个文章完成. 上次说到了设计原则中的单一职责原则,今天时间比较紧,我就继续往下写,也不 ...

最新文章

  1. 写给MongoDB开发者的50条建议Tip25
  2. Linux下修复修改profile文件导致命令不用可的解决方法
  3. Java学习_day001
  4. 如果C++程序要调用已经被编译后的C函数,该怎么办?
  5. Android通用流行框架汇总
  6. web.config中httpRunTime的属性(转)
  7. mysql 5.7.21 主从_Mysql 5.7.21 设置主从库同步
  8. Learning to rank基本算法小结
  9. 【转】医疗业务学习笔记--DICOM协议的基础内容!!!!!!!!!!
  10. 《Python Cookbook 3rd》笔记(5.17):将字节写入文本文件
  11. textview字体切换颜色_百元耳机支持主从切换,关键双耳双麦还能立体降噪
  12. 基于 Springboot 和 Mybatis 的后台管理系统 BootDo
  13. jpa 连接多个mysql 数据库_SpringBoot 连接多个数据库
  14. FastDFS学习总结(2)--Tracker与Storage配置详解
  15. CANoe——CAPL
  16. atoll C语言实现
  17. error: comparison between distinct pointer types ‘char*’ and ‘unsigned char*’ lacks a cast 解决方法
  18. ie11无法播放html,IE11无法显示flash?IE11无法播放视频的解决方法
  19. 如何快速成为CSDN的博客专家,以及「博客专家」申请及审核执行标准
  20. C++综合练习——身份证

热门文章

  1. MATLAB学习之数列极限(一)
  2. AutoCAD 2010将不再安装VBA
  3. matlab脚本命令汇总
  4. 云存储Java客户端上传文件
  5. (攻防世界)(pwn)forgot
  6. 心里窝火无语的图片_失望无语的图片文字说说心情
  7. 大坝平台参考材料——志豪未来科技有限公司v2
  8. 文本字段的html标签是什么,HTML常用标签及属性
  9. 一款开源且具有交互视图界面的实时 Web 日志分析工具
  10. PTA 广西科技大学 胡伟平老师出的题目