说HTML语义化就要先说说HTML到底负责的什么?下面摘自维基百科:css
超文本标记语言(英语:HyperText Markup Language,简称:HTML)是一种用于建立网页的标准标记语言。
HTML元素是构建网站的基石。HTML容许嵌入图像与对象,而且能够用于建立交互式表单,它被用来结构化信息——例如标题、段落和列表等等,也可用来在必定程度上描述文档的外观和语义。
关于对于语义化的理解 顾轶灵:如何理解 Web 语义化?这里讲的很清楚了我就简单说一下个人理解:
通俗的来说就是从代码上来展现页面的结构,而不是从最终视觉上来展现结构。单纯的HTML代码是 不带任何样式的只是用来标记这一段是标题、这一块是代码、那一个是要强调的内容等等,可是为何咱们只写HTML在浏览器中不一样的标签也是有不一样的样式呢?那是由于各个浏览器都自带的有相应标签的默认样式,为了方便在没有设定样式的状况下友好的展现页面。
良好的语义化代码能够直接从代码上就能看出来那一块究竟是要表达什么内容。
为何要使用语义化标签?我用DIV+CSS也能作出来同样的效果,确实单纯看效果二者并无什么区别,可是页面不止是给人看的,机器也要看爬虫也要看。
网页结构更清晰方便开发维护:html
另外,在网络或其余缘由页面样式文件丢失的时候,尽是div组成的页面和良好语义结构组成的页面那个对用户更友好?html5
看一下大厂的操做,打开淘宝的页面查看它首页的源码发现,全局只有一个h1标签就是他的LOGO。segmentfault
再往下看主题分栏的标题是h2浏览器
再往下看,分栏都是用的h3标签,而且内部使用了一个隐藏的<em></em>
专门强调处理。网络
尽管这些东西都是用div+css就能搞出来的,可是它仍是专门使用了相应的语义化标签来强调做用。ide
<h1>
~<h6>
,做为标题使用,而且依据重要性递减,<h1>
是最高的等级。<p>
段落标记,知道了 <p>
做为段落,你就不会再使用 <br />
来换行了,并且不须要 <br />
来区分段落与段落。<p>
中的文字会自动换行,并且换行的效果优于 <br />
。段落与段落之间的空隙也能够利用 CSS 来控制,很容易并且清晰的区分出段落与段落。<ul>
、<ol>
、<li>
,<ul>
无序列表,这个被你们普遍的使用,<ol>
有序列表不经常使用。在 Web 标准化过程当中,<ul>
还被更多的用于导航条,原本导航条就是个列表,这样作是彻底正确的,并且当你的浏览器不支持 CSS 的时候,导航连接仍然很好使,只是美观方面差了一点而已。<dl>
、<dt>
、<dd>
,<dl>
就是“定义列表”。好比说词典里面的词的解释、定义就能够用这种列表。dl不单独使用,它一般与dt和dd一块儿使用。dl开启一个定义列表,dt表示要定义的项目名称,dd表示对dt的项目的描述。 <em>
、<strong>
,<em>
是用做强调,<strong>
是用做重点强调。<table>
、<thead>
、<tbody>
、<td>
、<th>
、<caption>
, 就是用来作表格不要用来布局HTML5标准更加的讲究语义化了,借用一张网上的图来讲明这些新标签工具
header元素
:header 元素表明“网页”或“section”的页眉。footer元素
:footer元素表明“网页”或“section”的页脚,一般含有该节的一些基本信息,譬如:做者,相关文档连接,版权资料。hgroup元素
:nav元素
:nav元素表明页面的导航连接区域。用于定义页面的主要导航部分。aside元素
:aside元素被包含在article元素中做为主要内容的附属信息部分,其中的内容能够是与当前文章有关的相关资料、标签、名次解释等。(特殊的section)section元素
:section元素表明文档中的“节”或“段”,“段”能够是指一篇文章里按照主题的分段;“节”能够是指一个页面里的分组。section一般还带标题,虽然html5中section会自动给标题h1-h6降级,可是最好手动给他们降级。article元素
:article元素最容易跟section和div容易混淆,其实article表明一个在文档,页面或者网站中自成一体的内容,其目的是为了让开发者独立开发或重用。譬如论坛的帖子,博客上的文章,一篇用户的评论,一个互动的widget小工具。(特殊的section)除了它的内容,article会有一个标题(一般会在header里),会有一个footer页脚。推荐看原博主的博客:传送门布局