【原】HTML5 新增的结构元素——能用并不代表对了

简介:

做移动端有一段时间,今天有同事问了我 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权威指南》

作者:白树

出处:http://peunzhang.cnblogs.com/

目录
相关文章
|
1月前
|
移动开发 HTML5
HTML5的基本结构
HTML5的基本结构。
33 5
|
1月前
|
移动开发 开发者 UED
HTML5 语义元素详解
HTML5引入了诸多语义元素
WK
|
1月前
|
存储 移动开发 前端开发
HTML5新增了哪些其他元素和属性
这段文字介绍了HTML5中新增的多种元素和属性,包括页面布局元素如header、nav等,表单元素如email、tel输入框等,以及其他元素如canvas、svg等。此外,还介绍了全局及表单属性,例如contenteditable、placeholder等,这些新功能显著增强了HTML5在现代网页设计与开发中的实用性与灵活性。
WK
48 1
|
2月前
|
JavaScript 前端开发 容器
用HTML DOM实现有条件地渲染网页元素(上)
用HTML DOM实现有条件地渲染网页元素(上)
|
2月前
|
存储 JavaScript 前端开发
用HTML DOM实现有条件地渲染网页元素(下)
用HTML DOM实现有条件地渲染网页元素(下)
|
17天前
HTML 元素
HTML文档由HTML元素定义,元素包括开始标签、内容和结束标签。某些元素内容为空,可在开始标签中关闭。大多数元素可拥有属性,且元素间可相互嵌套,形成复杂结构。
|
1月前
|
移动开发 数据安全/隐私保护 UED
HTML5 表单元素详解
HTML5 引入了新的表单元素和属性,如 `&lt;form&gt;、&lt;input&gt;、&lt;textarea&gt;、&lt;select&gt;` 和 `&lt;button&gt;`,以及 `required、min、max` 等属性,增强了表单的创建与交互。其中,`&lt;input&gt;` 支持多种类型如 `email、url、date` 等,提供了更好的用户体验和数据验证。此外,HTML5 还新增了原生表单验证功能,简化了开发流程并提升了安全性。
WK
|
1月前
|
Web App开发 存储 移动开发
HTML5新增了哪些表单元素
HTML5通过新增多种表单元素和属性,提升了用户体验与交互性。例如,`email`和`url`元素分别验证邮箱地址和网址格式;`number`和`range`便于输入数字及区间值;`date`等元素简化了日期时间的选择;`search`添加搜索图标,`color`提供颜色选择器;`datalist`结合`input`属性给予用户下拉列表选项;`keygen`用于生成密钥对以增强安全性;`output`则用于动态展示计算结果。这些改进共同提高了表单的功能性和易用性。
WK
24 2
|
21天前
|
移动开发 HTML5
一个最简单的 HTML 页面结构如下:
HTML 是一种标记语言,用于描述网页结构。通过 `&lt;html&gt;`, `&lt;head&gt;`, `&lt;body&gt;` 等标签构建页面,支持文本、图像、链接、表格等多种元素。本文介绍了 HTML 基础,包括常用标签及创建简单网页的实例,帮助初学者快速入门。
54 0
|
30天前
|
数据采集 数据安全/隐私保护
html常见的表单元素有哪些,html表单元素有哪些?
html常见的表单元素有哪些,html表单元素有哪些?
15 0