div这个标签是使用最多的一个标签,本身没有任何语义,用作布局以及样式化或脚本的钩子。
section与 div 的无语义相对,简单地说 section 就是带有语义的 div 了。section 表示一段专题性的内容,一般会带有标题。一篇博客文章,或者一条单独的评论正好可以用 section 吗?接着看:
当元素内容聚合起来更加言之有物时,应该使用 article 来替换 section 。
那么,section 应该什么时候用呢?再接着看:
section 应用的典型场景有文章的章节、标签对话框中的标签页、或者论文中有编号的部分。一个网站的主页可以分成简介、新闻和联系信息等几部分。其实我对这里传达信息很感兴趣,因为感觉 section 和下面要介绍的 artilce 更加适用于模块化应用,这个话题以后会出篇专门的文章来讨论,这里暂时略过。
要注意,W3C 还警告说:
section 不仅仅是一个普通的容器标签。当一个标签只是为了样式化或者方便脚本使用时,应该使用 div 。一般来说,当元素内容明确地出现在文档大纲中时,section 就是适用的。
article 是一个特殊的 section 标签,它比 section 具有更明确的语义, 它代表一个独立的、完整的相关内容块。一般来说, article 会有标题部分(通常包含在 header 内),有时也会 包含 footer 。虽然 section 也是带有主题性的一块内容,但是无论从结构上还是内容上来说,article 本身就是独立的、完整的。
HTML Spec 中接着又列举了一些 article 适用的场景。 当 article 内嵌 article 时,原则上来说,内部的 article 的内容是和外层的 article 内容是相关的。例如,一篇博客文章中,包含用户提交的评论的 article 就应该潜逃在包含博客文章 article 之中。
问题是怎么才算“完整的独立内容”?有个最简单的判断方法是看这段内容在 RSS feed 中是不是完整的。看这段内容脱离了所在的语境,是否还是完整的、独立的。
总结
div section article ,语义是从无到有,逐渐增强的。div 无任何语义,仅仅用作样式化或者脚本化的钩子(hook),对于一段主题性的内容,则就适用 section,而假如这段内容可以脱离上下文,作为完整的独立存在的一段内容,则就适用 article。原则上来说,能使用 article 的时候,也是可以使用 section 的,但是实际上,假如使用 article 更合适,那么就不要使用 section 。nav 和 aside 的使用也是如此,这两个标签也是特殊的 section,在使用 nav 和 aside 更合适的情况下,也不要使用 section 了。
对于 div 和 section、 article 以及其他标签的区分比较简单。对于 section 和 article 的区分乍看比较难,其实重点就是看看这段内容脱离了整体是不是还能作为一个完整的、独立的内容而存在,这里面的重点又在完整身上。因为其实说起来 section 包含的内容也能算作独立的一块,但是它只能算是组成整体的一部分,article 才是一个完整的整体。
因为其实有些时候每个人都有自己的看法,所以难免有难于决断的时候,怎么办?
在 HTML5 设计原理 中,有一条是专门用来解决类似情况的:
最终用户优先(Priority of Constituencies)
一旦遇到冲突,最终用户优先,其次是作者,其次是实现者,其次标准制定者,最后才是理论上的完满。
分享到:
相关推荐
因此,正确使用 div、section 和 article 可以增强文档的结构清晰度,提升用户体验。在不确定何时使用哪个标签时,思考一下内容是否具有独立性,是否有标题,以及它在文档大纲中的位置,这将帮助你做出正确的选择。
尤其是对 div、section、article 这几个标签,实在弄不清楚应该使用在什么场合下。div HTML Spec: The div element has no special meaning at all. 这个标签是我们见得最多、用得最多的一个标签。本身没有任何...
HTML5在原有的HTML基础上增加了一些新的标签,如`<header>`、`<nav>`、`<section>`、`<article>`、`<aside>`和`<footer>`等,这些标签提供了更好的语义化,使得网页结构更加清晰。同时,HTML5还引入了离线存储、拖放...
尽可能地使用有语义的HTML元素(如`header`、`footer`、`article`、`section`等)替代无语义的`div`,以提高页面的可读性和可访问性。 3. **类选择器**: - 为了更好地管理和定位`div`,应为其指定类名,而不是...
2. **避免错误选择**:如果`<article>`、`<aside>`或`<nav>`标签更符合实际需求,就不应该使用`<section>`。 3. **不要为无标题的内容使用`<section>`**:如果某个内容块没有合适的标题,则不应该使用`<section>`...
例如,使用语义化的`<article>`, `<section>`或`<figure>`标签代替单纯的div,提高可访问性和SEO性能。 8. **测试与调试**:在不同浏览器和设备上测试转换后的页面,确保所有功能正常,布局无误。 在提供的压缩包...
HTML5引入了新的标签,如`<header>`, `<nav>`, `<article>`, `<section>`, `<aside>`和`<footer>`,这些元素有助于创建更有语义化的网页结构。此外,HTML5还支持离线存储、拖放功能、媒体元素(如`<audio>`和`...
在网页设计领域,CSS(Cascading Style Sheets)与DIV元素是构建现代...在实际工作中,结合HTML5的新特性,如section、article、nav等语义化标签,以及现代布局技术如Grid和Flexbox,可以更好地应对各种网页布局挑战。
HTML5引入了更多语义化的标签,如`<header>`, `<footer>`, `<section>`和`<article>`,以提高内容的可读性和SEO优化。 CSS(Cascading Style Sheets)则负责网页的样式和布局。通过选择器(如元素选择器,类选择器...
在“绝对实用的DIV+CSS+JQUERY模板”中,HTML文件将使用不同的标签如`<div>`、`<header>`、`<nav>`、`<section>`、`<article>`等来组织页面结构,以便更好地展示信息和内容。 【CSS】:Cascading Style Sheets...
HTML是构建网页内容的核心,通过不同的标签如`<head>`、`<body>`、`<header>`、`<nav>`、`<section>`、`<article>`、`<footer>`等定义网页的结构。在这个旅游网站中,可能会包含首页、目的地介绍、旅行攻略、联系...
不过,需要注意的是,如果只是为了应用样式或者方便脚本操作,推荐使用<div>元素,因为<div>更具有通用性,而<section>应当用于有特定语义的结构划分。 其次,Article元素则是用于定义独立的、自包含的内容,这些...
HTML5引入了更多的语义化元素,如、、<section>、<article>、和,这些可以帮助构建更加结构化的网页,提高可读性和可访问性。同时,HTML5也增加了新的表单元素和API,如用于图形绘制,和用于多媒体播放,以及Web存储...
3. **嵌套使用**:`<section>`可以被嵌套在其他`<section>`或者`<article>`元素中,以创建更复杂的文档结构。但是过度嵌套可能会导致结构混乱,应当适度使用。 4. **与`<div>`的区别**:`<div>`是一个通用的容器...
2. 主体区域(Main Content):展示个人简介、作品集或博客文章,可以使用`section`或`article`元素,利用CSS实现网格布局。 3. 侧边栏(Sidebar):可放置联系信息、社交媒体链接或热门文章列表,使用`aside`元素...
- 这种说法忽略了HTML的其他标签,如`<span>`、`<article>`、`<section>`等,它们同样可以与CSS结合使用来实现布局效果。 - “DIV+CSS”容易让人误以为只有`<div>`标签才能用来布局,实际上任何HTML元素都可以通过...
例如,`<header>`、`<nav>`、`<section>`、`<article>`、`<footer>`等语义化标签,使得页面结构更加清晰,有利于SEO(搜索引擎优化)。此外,HTML5还支持音频、视频等多媒体内容的直接嵌入,以及canvas(画布)和svg...