HTML5 设计原理笔记

2018-03-26  本文已影响0人  TRYao

今天拜读了HTML5 设计原理,算是重新认识了html5,这里做下笔记总结。

  1. 设计原理
    设计原理本质上是一种信念、一种想法、一个概念,是你行动的支柱。
  2. HTML
    伯斯塔尔法则(Postel’s Law):发送时要保守;接收时要开放。
  3. HTML5
    HTML5必将是一个伟大的规范,而W3C与WHATWG已经认可这就是他们的共同行动纲领。
  4. 避免不必要的复杂性
<!DOCTYPE html>
<meta charset="utf-8">
  1. 支持已有的内容
    在HTML5中,你可以随意使用下列任何语法:
<img src="foo" alt="bar" />
<p class="foo">Hello world</p>

<img src="foo" alt="bar">
<p class="foo">Hello world

<IMG SRC="foo" ALT="bar">
<P CLASS="foo">Hello world</P>

<img src=foo alt=bar><p class=foo>Hello world</p>
  1. 解决现实的问题
<h2><a href="/path/to/resource">Headline text</a></h2>
<p><a href="/path/to/resource">Paragraph text.</a></p>

在HTML5中,我只要简单地把所有内容都包装在一个链接元素中就行了。

<a href="/path/to/resource">
    <h2>Headline text</h2>
    <p>Paragraph text.</p>
</a>
  1. 求真务实
<div class="item">
    <h2>...</h2>
    <div class="meta">...</div>
    <div class="content">...</div>
    <div class="links">...</div>
</div>

可替换为

<body>
    <header>...</header>
    <nav>...</nav>
    <div id="main">...</div>
    <aside>...</aside>
    <footer>...</footer>
</body>

即便是现在,你照样可以使用div和类来描述页面中不同的部分,就像下面这样:

<div class="item">
    <h2>...</h2>
    <div class="meta">...</div>
    <div class="content">...</div>
    <div class="links">...</div>
</div>

其中包含可能是有关内容作者的元数据,而下面会给出一些链接,差不多就这样。在HTML5中,我完全可以说这块内容就是一个文档,通过对内容分区,使用section或article或aside,我可以说“这一块完全是可以独立存在的。”因此,我当然可以使用header和footer。

<section class="item">
    <header><h1>...</h1></header>
    <footer class="meta">...</footer>
    <div class="content">...</div>
    <nav class="links">...</nav>
</section>

这个变化太厉害了。想一想吧,这个变化对内容管理是革命性的。因为现在,你可以把每个内容分区想象一个独立的、能够从页面中拿出来的部分。此时,根据上下文不同,这个独立部分中的H1,在整个页面中没准会扮演H2或H3的角色——取决于它在文档中出现的位置。面对这个突如其来的变化,也许有人的脑子会暂时转不过弯来。不要紧,但我可以告诉你,我认为这才是HTML5中这些新语义标记的真正价值所在。换句话说,我们现在有了独立的元素了,这些元素中的标题级别可以重新定义。

  1. 平稳退化
    有关HTML5遵循这条原理的例子,就是使用type属性增强表单。
    input type="number"
    input type="search"
    input type="range"
    input type="email"
    input type="date"
    input type="url"

现有的浏览器,不是将来的浏览器,现有的浏览器是无法理解这些新type值的。但在它们看到自己不理解的type值时,会将type的值解释为text。

<video>
    <source src="movie.mp4">
    <source src="movie.ogv">
    <object data="movie.swf">
        <a href="movie.mp4">download</a>
    </object>
</video>

上面的代码中包含了4个不同的层次。

1).如果浏览器支持video元素,也支持H264,没什么好说的,用第一个视频。
2).如果浏览器支持video元素,支持Ogg,那么用第二个视频。
3).如果浏览器不支持video元素,那么就要试试Flash影片了。
4).如果浏览器不支持video元素,也不支持Flash,我还给出了下载链接。

  1. 最终用户优先
    一旦遇到冲突,最终用户优先,其次是作者,其次是实现者,其次标准制定者,最后才是理论上的完满。
    软件,就像所有技术一样,具有天然的政治性。代码必然会反映作者的选择、偏见和期望。
    所以,我认为平常多看一看别人推崇的设计原理,有助于做好自己手头的工作。你可以把自己认为有道理的设计原理贴在墙上。当然,你可以维护一个URL,把自己认为有价值的设计原理分享出来,就像Mozilla基金会那样,对不对,以下是Mozilla的设计原理:
    Internet作为一种公共资源,其运作效率取决于互通性(协议、数据格式、内容)、变革及全球范围内的协作。
    基于透明社区的流程有助于增进协作、义务和信任。

我觉得像这样的设计原理都非常好。而有了设计原理,我认为才更有希望设计出真正有价值的产品。设计原理是Web发展背后的驱动力,也是通过HTML5反映出来的某种思维方式。

上一篇 下一篇

猜你喜欢

热点阅读