在HTML5之前,使用机器来阅读一个网页是非常困难的,我们使用不同样式的div来标记不同的内容,所以实际上机器无法得知页面的哪个部分是正文,哪个部分是标题,那么在HTML5里,针对这个问题就引入了语义化的概念,同时提供了新的标签来指定对应的内容类型。
div本身就是没有任何额外意义的,作为一个纯粹的容器用来进行css的样式定义的,他只是一个标签,仅仅是用来构建外观和结构。因此是最适合做容器的标签。所以不能因为有了HTML5的新标签就弃用了div,每个事物都有它的独有作用的。div就是只是想用来把元素组合或者给它们加样式时使用。
header 元素代表“网页”或“section”的页眉。
通常包含h1-h6元素或hgroup,作为整个页面或者一个内容块的标题。也可以包裹一节的目录部分,一个搜索框,一个nav,或者任何相关logo。
整个页面没有限制header元素的个数,可以拥有多个,可以为每个内容块增加一个header元素:
1 <header> 2 <hgroup> 3 <h1>网站标题</h1> 4 <h1>网站副标题</h1> 5 </hgroup> 6 </header>
header使用注意:
footer元素代表“网页”或“section”的页脚,通常含有该节的一些基本信息,譬如:作者,相关文档链接,版权资料。如果footer元素包含了整个节,那么它们就代表附录,索引,提拔,许可协议,标签,类别等一些其他类似信息。
1 <footer> 2 COPYRIGHT@小C 3 </footer>
footer使用注意:
hgroup元素代表“网页”或“section”的标题,当元素有多个层级时,该元素可以将h1到h6元素放在其内,譬如文章的主标题和副标题的组合
1 <hgroup> 2 <h1>这是一篇介绍HTML 5语义化标签和更简洁的结构</h1> 3 <h2>HTML 5</h2> 4 </hgroup>
hgroup使用注意:
nav元素代表页面的导航链接区域。用于定义页面的主要导航部分。
1 <nav> 2 <ul> 3 <li>HTML 5</li> 4 <li>CSS3</li> 5 <li>JavaScript</li> 6 </ul> 7 </nav>
但是我在有些时候却情不自禁的想用它,譬如:侧边栏上目录,面包屑导航,搜索样式,或者下一篇上一篇文章,但是事实上规范上说nav只能用在页面主要导航部分上。页脚区域中的链接列表,虽然指向不同网站的不同区域,譬如服务条款,版权页等,这些footer元素就能够用了。
nav使用注意:
aside元素被包含在article元素中作为主要内容的附属信息部分,其中的内容可以是与当前文章有关的相关资料、标签、名次解释等。(特殊的section)
在article元素之外使用作为页面或站点全局的附属信息部分。最典型的是侧边栏,其中的内容可以是日志串连,其他组的导航,甚至广告,这些内容相关的页面。
1 <article> 2 <p>内容</p> 3 <aside> 4 <h1>作者简介</h1> 5 <p>小北,前端一枚</p> 6 </aside> 7 </article>
aside使用总结:
section元素代表文档中的“节”或“段”,“段”可以是指一篇文章里按照主题的分段;“节”可以是指一个页面里的分组。
section通常还带标题,虽然html5中section会自动给标题h1-h6降级,但是最好手动给他们降级。如下:
1 <section> 2 <h1>section是啥?</h1> 3 <article> 4 <h2>关于section</h1> 5 <p>section的介绍</p> 6 <section> 7 <h3>关于其他</h3> 8 <p>关于其他section的介绍</p> 9 </section> 10 </article> 11 </section>
section使用注意:
article元素最容易跟section和div容易混淆,其实article代表一个在文档,页面或者网站中自成一体的内容,其目的是为了让开发者独立开发或重用。譬如论坛的帖子,博客上的文章,一篇用户的评论,一个互动的widget小工具。(特殊的section)
除了它的内容,article会有一个标题(通常会在header里),会有一个footer页脚。我们举几个例子介绍一下article,好更好区分article、section、div:
1 <article> 2 <h1>一篇文章</h1> 3 <p>文章内容..</p> 4 <footer> 5 <p><small>版权:html5jscss网所属,作者:小北</small></p> 6 </footer> 7 </article>
article使用注意:
作为联系信息出现,邮编地址、邮件地址等等,一般出现在footer。
用来标记一篇文章的发布时间。
<time datetime="2012-02-15" pubdate>2012年02月15日</time>
一般有三个组成部分
我们还要注意的是,如果该time位于一个article中,那么它表示这篇文章的发布时间;如果不在article之中表示整个文档的发布时间。
1 <article> 2 <header> 3 <h1>html5jscss网<time datetime="2012-02-14">2月14日</time>成立</h1> 4 <p>发布 <time datetime="2012-02-15" pubdate>2012年02月15日</time> 分类:前端交流</p> 5 </header> 6 <p>你好世界!</p> 7 </article>
原文:http://www.cnblogs.com/hammerc/p/6368487.html