语义
程序设计中,语义指的是一段代码的含义。例如,“运行这行 JavaScript 代码会产生怎样的影响?”、“这个 HTML 的元素有什么作用,扮演了什么样的角色”(而不只是“它看上去像是什么?”)
JavaScript 中的语义
JavaScript 中,考虑一个函数,该函数接受一个字符串参数,然后返回一个以该字符串为文本内容的 <li>
元素。如果该函数调用是 build('Peach')
,你会需要去看代码才能理解该函数做了什么吗?createLiWithContent('Peach')
呢?
CSS 中的语义
CSS 中,考虑给一个列表设置样式,li
元素代表不同类型的水果。通过 div > ul > li
,你能知道 DOM 的那一部分会被选择中吗?但如果是 .fruits__item
呢?
HTML 中的语义
HTML 中,例如,<h1>
元素是一个语义化元素,赋予了它包裹着的文本“这个页面中最高级别标题”的角色(或含义) 。
<h1>这是顶级标题</h1>
默认情况下,绝大多数浏览器的用户代理样式表会赋予 <h1>
元素很大的字号尺寸从而让它看上去更像是一个标题(虽然你可以把它格式化为任何你想要的样式)。
另一方面,你可以让任何的元素看上去像是最高级别的标题,就像下面所展示的一样:
<span style="font-size: 32px; margin: 21px 0;">这不是一个顶级标题!</span>
这会让它看上去像是一个顶级标题,但是它没有语义价值,所以它不会得到上面描述的额外的好处。因此,使用正确的 HTML 元素来做正确的工作是一个好主意。
HTML 应该编写为表示将要填充的数据,而不是基于其默认的演示样式。演示(应该是什么样子),是 CSS 的唯一责任。
写语义标记的一些好处如下:
- 搜索引擎将其内容视为影响页面搜索排名的重要关键字(参见 SEO)。
- 屏幕阅读器可以将其用作指引,帮助视力受损的用户导航页面。
- 比起搜索无休止的带有或不带有语义/命名空间类的
div
,找到有意义的代码块显然容易得多。 - 向开发人员建议将要填充的数据类型。
- 语义命名反映了正确的自定义元素/组件命名。
当接近要使用的标记时,问问自己,“什么元素最能描述/表示我要填充的数据?”例如,它是数据列表吗?有序或无序?是否是一篇具有章节和相关信息旁注的文章?它是否列出了定义?它是需要标题的图形还是图像?除了全局网站范围的页眉和页脚之外,它还应该有页眉和页脚吗?等等。
语义化元素
参见
- MDN 上的 HTML 元素参考
- MDN 上的使用 HTML 章节和大纲
- 维基百科上的计算机科学中语义的意义
- 术语