做移动端有一段时间,今天有同事问了我 article 和 section 标签的使用,模模糊糊的解释了下,他似懂非懂,有点小尴尬。忽然间觉得自己有必要再翻翻书籍,重温下 html5 的新元素。html5 新增的结构元素,有的经常使用到,有的用不上,当页面禁用样式后,它们的展现跟 div 是没撒差别,有同学可能会说,既然一样,又不影响页面的最终展现,不管是 article 还是 section 能用就好了。如果考虑实际项目针对用户,我也是这么认为的,但作为一个重构仔,我们需要让标签语义化,清晰的结构,更好的 seo,利于特殊终端的阅读(无障碍),此时 html5 标签的作用就很明显了,并不是说能用就好。于是复习下内容并记录在博客上,顺便分享给大家,也方便自己以后查找。

HTML5 新增结构元素分为主体结构元素和非主体结构元素

  • 主体结构元素: article、section、nav、aside、time
  • 非主体结构元素:header、hgroup、footer、address

一、主体结构元素

article

article 标签,从语义化上看为文档、页面,其用法如下:

  • 通常是一篇文章、一个页面、一个独立完整的内容模块
  • 一般会带个标题,并放在 header 标签中
  • article 元素可以互相嵌套

使用频率极高,强调独立性,多注意下与 header 标签的使用。

<article>
<header>
<h1>是我标签</h1>
</header>
<p>我是段落</p>
<article>
<div>我的内容</div>
</article>
</article>

section

section 标签,从语义化上看为部分,其用法如下:

  • 用于页面内容的独立分块,往往是文章的一段
  • 通常由内容和标题组成,没有标题的内容不推荐使用 section

使用频率低,强调分段分块。

注:《HTML5与CSS3权威指南》这本书中说明:一个容器需要被定义样式或者脚本定义行为时,推荐用div而非section,不要将section用作设置样式的容器。

<section>
<h1>水果</h1>
<article>
<h2>苹果</h2>
<div>苹果是撒?</div>
</article>
<article>
<h2>桔子</h2>
<div>桔子是撒?</div>
</article>
</section>
<!-- article可以看成是一种特殊种类的section元素,它比section更强调独立性 -->
<article>
<h1>中国人物</h1>
<p>三国、两晋、南北朝</p>
<section>
<h2>三国</h3>
<p>猛将猛将猛将猛将</p>
</section>
<section>
<h2>两晋</h3>
<p>猛将猛将猛将猛将</p>
</section>
</article>

nav

nav 标签,从语义化上看为导航,其用法如下:

  • 通常作为页面导航的链接组
  • 侧边栏导航

使用频率高。

<nav>
<ul>
<li><a href="">菜单1</a></li>
<li><a href="">菜单2</a></li>
<li><a href="">菜单3</a></li>
</ul>
</nav>

aside

aside 标签,从语义化上看为在旁边、侧边,其用法如下:

  • 在 article 标签中使用时,作为主要内容的附属信息部分,如有关的参考资料、名词解释等。
  • 在 article 标签外使用时,作为页面或者站点全局的附属信息部分,如侧边栏、博客的友情链接部分、广告区域等。

使用频率低。

<!-- 在article标签外使用时 -->
<article>
<h1>马云是谁</h1>
<p>马云,男,1964年10月15日出生于浙江省杭州市,中国著名企业家,阿里巴巴集团、淘宝网、支付宝创始人..........</p>
<aside>
<h1>参考资料</h1>
<p>百度网、维基百科...</p>
</aside>
</article> <!-- 在article标签内使用时 -->
<aside>
<nav>
<ul>
<li><a href="">老赵的博客</a></li>
<li><a href="">鬼哥的博客</a></li>
<li><a href="">彪叔的博客</a></li>
</ul>
</nav>
</aside>

time

time 标签,从语义化上看为时间,其用法如下:

  • 代表 24 小时中的某个时刻或某个日期
  • 表示时刻时允许带时间差
  • 可定义很多格式的日期和时间

使用频率低。

<time datetime="2013-3-6">2014年3月6日</time>
<!-- datetime 属性中日期与时间之间要用"T" 分隔,"T'表示时间 -->
<time datetime="2013-3-6T20:00">2014年3月6日20:00</time>
<!-- 时间加上"Z"表示给机器编码时使用 UTC 标准时间 -->
<time datetime="2013-3-6T20:00Z">2014年3月6日20:00</time>

二、非主体结构元素

header

header 标签,从语义化上看为文档的页眉,其用法如下:

  • 一种具有引导和导航作用的结构元素
  • 通常放置在整个页面或者页面内的一个内容区块的标题
  • 一个网页内并没有限制 header 标签的个数

使用频率极高,比较容易理解。

<header>
<h1>我是大头</h1>
</header>
<article>
<header>
<h1>我是脖子</h1>
</header>
<p>我是身体</p>
</article>

hgroup

hgroup 标签,从语义化上看为标题组,其用法如下:

  • 作为 header 标签的子元素
  • 一个内容模块中包括了主标题和至少一个子标题才使用 hgroup
  • 通常会将 h1~h6 元素进行分组

使用频率高。

<article>
<header>
<hgrounp>
<h1>我是刘备</h1>
<h2>我是关羽</h2>
<h3>我是张飞</h3>
</hgrounp>
</header>
<p>吕布惊呆了</p>
</article>

footer

footer 标签,从语义化上看为文档的脚注,其用法如下:

  • 一个内容块区的脚注
  • 通常内容为联系信息、相关阅读、版权信息等

使用频率高,比较容易理解。

<article>
<p>吕布惊呆了</p>
<footer>
<ul>
<li>关于三国</li>
<li>地图信息</li>
<li>游戏攻略</li>
</ul>
</footer>
</article>

address

address 标签,从语义化上看为地址,其用法如下:

  • 用于文档中呈现的联系信息
  • 通常内容为作者、网站链接、电子邮箱、地址、电话号码等

使用频率低。

<address>
<a href="">作者:张三丰</a>
<a href="">地址:武当山</a>
<a href="">联系方式:1247</a>
</address>

感谢webapp群的猎巫同学提醒,这个属性其实HTML 4.01就已经有了,这里修正下。

希望本文对大家在 html5 结构标签上的运用有一定的指导,如果发现内容有错误的地方,欢迎大家指正~

参考资料《HTML5与CSS3权威指南》

【原】HTML5 新增的结构元素——能用并不代表对了的更多相关文章

  1. HTML5新增的结构元素

    HTML5的结构 一:新增的主体结构元素 在HTML5中,为了使文档的结构更加清晰明确,追加了几个与页眉,页脚内容区块等文档结构相关联的结构元素. 1.1article元素 article元素代表文档 ...

  2. HTML5新增与结构有关的元素

    HTML5新增与结构有关的元素 1.section元素 2.article元素 3.aside元素 4.header元素 5.hgroup元素 6.footer元素 7.nav元素 8.figure元 ...

  3. html5--select与HTML5新增的datalist元素

    html5--select与HTML5新增的datalist元素 学习要点 掌握select元素与datalist元素的使用 select元素 用来建立一个下拉菜单选项列表 不仅可以在表单中使用,还可 ...

  4. 疯狂的表单-html5新增表单元素和属性

    疯狂的表单 2015/11/27 16:44:07 从三方面来介绍html5表单的新特性 表单结构更灵活 要提交数据的控件可以布局在form标签之外,看下面的代码,表单元素可以写到form元素之外,只 ...

  5. 读书笔记:《HTML5开发手册》--HTML5新的结构元素

    读书笔记:<HTML5开发手册> (HTML5 Developer's CookBook) 虽然从事前端开发已有很长一段时间,对HTML5标签也有使用,但在语义化上面理解还不够清晰.之前在 ...

  6. 如何让老式浏览器支持html5新增的语义元素

    html5新增加了一些语义元素,如header, footer, nav, aritcle, aside,等等. 然而,有些老款浏览器无法识别这些元素,会把它们当成 inline 元素对待,这会导致一 ...

  7. 第一章 用HTML5中的结构元素构建网站

    1.当一个容器需要直接定义样式或通过脚本定义行为时,推荐使用div元素而非section元素. 2.section是需要标题的,而nav或aside没有标题也是可以的. 3.html5轮廓工具 htt ...

  8. IT兄弟连 HTML5教程 HTML5表单 HTML5新增表单元素

    HTML5有一些新的表单元素:<datalist>.<keygen>.<output>.不是所有的浏览器都支持HTML5新的表单元素,但即使浏览器不支持该表单属性, ...

  9. html5新增的主体结构元素

    1.  article 主体结构元素 通常是一篇文章.一个页面.一个独立完整的内容模块一般会带个标题,并放在 header 标签中,article 元素可以互相嵌套,使用频率极高,强调独立性,多注意下 ...

随机推荐

  1. NHibernate生成实体类、xml映射文件

    最近工作电脑装完win10后,之前使用的codeSmith安装不了,索性自己写一个. 界面比较简单,如下图: 第一行为Oracle数据库的连接字符串.连接成功后,填充表到第4行的下拉列表中. 第二行为 ...

  2. C#图片加水印实例与代码

    本文要提供的类可以为图片加文字水印,以及判断是否是图片文件.经过测试可运行,例子请下载:http://hovertree.com/h/bjaf/5qc5eh6y.htm 例子效果图: 以下是Hover ...

  3. StackExchange.Redis加载Lua脚本进行模糊查询的批量删除和修改

    前言 使用StackExchange.Redis没有直接相关的方法进行模糊查询的批量删除和修改操作,虽然可以通过Scan相关的方法进行模糊查询,例如:HashScan("hashkey&qu ...

  4. C#集合--Dictionary

    字典(dictionary)是一个集合,其中每个元素都是一个键/值对.字典(Dictionaries)是常用于查找和排序的列表. .NET Framework通过IDictionary接口和IDict ...

  5. 关于项目中值对象Identifier的设计-领域驱动

    到现在为止做了不项目,发现每个实体都会有个相应的值对象. 先简单说一下值对象和实体之间的区别: (以下内容来着<领域驱动设计>一书) 当一个小孩画画的时候,他注意的是画笔的颜色和笔尖的粗细 ...

  6. EF架构~EF异步改造之路~让DbContextRepository去实现异步接口

    回到目录 返回异步与并行目录 上一讲中,我们定义了三个异步操作接口,这回我们将对它进行实现,而有一个基础知识需要大家清楚,那就是实现接口的方式,一般我们使用默认的方式(隐式实现),这种方法实现的接口方 ...

  7. MVC学习系列——Filter扩展

    在MVC中,Filter也是可以扩展的.在此,本人对Filter的理解就是AOP,不知道各位大侠,有什么高的见解,呵呵... 首先MVC四大过滤神器IAuthorizationFilter,IActi ...

  8. luogg_java学习_07_抽象类_接口_多态学习总结

    这篇博客总结了半天,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 , 抽象 一种专门用来做父类,被继承的. (模板) 格式: abs ...

  9. Ant_build.xml的最完整解释

    Ant的概念Make命令是一个项目管理工具,而Ant所实现功能与此类似.像make,gnumake和nmake这些编译工具都有一定的缺陷,但是Ant却克服了这些工具的缺陷.最初Ant开发者在开发跨平台 ...

  10. durex-word

    "(半夜没睡着) “你是不是饿了,哎呀我也饿了.”" "(聊到合拍处) “我和你有一万句me too想要说.”" "(异地恋) “我辞职,去你那儿吧! ...