面试题–你是如何理解 HTML 语义化的?
简单来说:就是用正确的标签做正确的事。比如:
头部:header 导航:nav 主体内容:main 标题:h1 ~ h6 段落:p 侧边栏:aside 页脚:footer
从历史讲起,大家知道前端也是这两年才发展起来的,以前的前端都是写写展示页,所以其实很早以前,是没有专门的前端的,需要写网页了,就让后端看看顺手写了,所以那时候的网页,都是一堆Table 或者 满屏幕的div标签。不要说给别人看自己的HTML结构了,估计自己也看的够累。而且对于搜索引擎和设备解析来说,非常的不友好。
发展路线:后端的table标签–>美工人员使用div+css布局–>讲专业的前端会使用正确的标签进行页面开发。

什么是HTML语义化?

单纯的HTML代码是不带任何样式的只是用来标记这一段是标题、这一块是代码、那一个是要强调的内容等等,但是为什么我们只写HTML在浏览器中不同的标签也是有不同的样式呢?那是因为各个浏览器都自带的有相应标签的默认样式,为了方便在没有设定样式的情况下友好的展示页面。
良好的语义化代码可以直接从代码上就能看出来那一块到底是要表达什么内容。

为什么要使用HTML语义化标签?

1.标签语义化有助于构架良好的HTML结构,有利于搜索引擎的建立索引、有助于爬虫抓取更多的有效信息.简单来说,试想在H1标签中匹配到的关键词和在div中匹配到的关键词搜索引擎会吧那个结果放在前面。
2.有利于不同设备的解析(屏幕阅读器,盲人阅读器等)满是div的页面这些设备如何区分那些是主要内容优先阅读?
3.有利于构建清晰的机构,有利于团队的开发、维护。
4.提升用户体验,例如title、alt可用于解释名词或解释图片信息。
5.网页加载慢导致CSS文件还未加载时(没有CSS),页面仍然清晰、可读、好看。

HTML5新增了哪些?


如上图那个页面结构没有一个div,都是采用html5语义标签,但是有些地方还是要用div的,就是因为div没有任何意义的元素,他只是一个标签,仅仅是用来构建外观和结构。因此div是最适合做容器的标签
**

HTML5中新增加的语义化标签和使用总结:

**
header元素
header 元素代表“网页”或“section”的页眉。
1.通常包含h1-h6元素或hgroup作为整个页面或者一个内容块的标题。也可以包裹一节的目录部分,一个搜索框,一个nav,或者任何相关logo。
2.整个页面没有限制header元素的个数,可以拥有多个,可以为每个内容块增加一个header元素。
3.hgroup 标签被用来对标题元素进行分组。
当标题有多个层级(副标题)时,hgroup 元素被用来对一系列 h1 - h6标签 元素进行分组。
4.如果hgroup或h1-h6自己就能工作的很好,那就不要用header。

<header><hgroup><h1>网站标题</h1><h1>网站副标题</h1></hgroup>
</header>

footer元素
1.footer元素代表“网页”或“section”的页脚,通常含有该节的一些基本信息,譬如:作者,相关文档链接,版权资料。如果footer元素包含了整个节,那么它们就代表附录,索引,提拔,许可协议,标签,类别等一些其他类似信息。
2.没有个数限制,除了包裹的内容不一样,其他跟header类似。

<footer>COPYRIGHT@小北
</footer>

hgroup元素
hgroup元素代表“网页”或“section”的标题,当元素有多个层级时,该元素可以将h1到h6元素放在其内,譬如文章的主标题和副标题的组合

<hgroup><h1>这是一篇介绍HTML 5语义化标签和更简洁的结构</h1><h2>HTML 5</h2>
</hgroup>

hgroup使用注意:
如果只需要一个h1-h6标签就不用hgroup
如果有连续多个h1-h6标签就用hgroup
如果有连续多个标题和其他文章数据,h1-h6标签就用hgroup包住,和其他文章元数据一起放入header标签

nav元素
nav元素代表页面的导航链接区域。用于定义页面的主要导航部分。

<nav><ul><li>HTML 5</li><li>CSS3</li><li>JavaScript</li></ul>
</nav>

aside元素
1.aside元素被包含在article元素中作为主要内容的附属信息部分,其中的内容可以是与当前文章有关的相关资料、标签、名次解释等。(特殊的section)

<article><p>内容</p><aside><h1>作者简介</h1><p>小北,前端一枚</p></aside>
</article>

2.在article元素之外使用作为页面或站点全局的附属信息部分。最典型的是侧边栏,没有article与之对应,最好不用,其中的内容可以是日志串连,其他组的导航,如果是广告,其他日志链接或者其他分类导航也可以用。
section元素
section元素代表文档中的“节”或“段”,“段”可以是指一篇文章里按照主题的分段;“节”可以是指一个页面里的分组。

section通常还带标题,虽然html5中section会自动给标题h1-h6降级,但是最好手动给他们降级。

<section><h1>section是啥?</h1><article><h2>关于section</h1><p>section的介绍</p><section><h3>关于其他</h3><p>关于其他section的介绍</p></section></article>
</section>

section使用注意:

1.一张页面可以用section划分为简介、文章条目和联系信息。不过在文章内页,最好用article。section不是一般意义上的容器元素,如果想作为样式展示和脚本的便利,可以用div。
2.article、nav、aside可以理解为特殊的section,所以如果可以用article、nav、aside就不要用section,没实际意义的就用div.

article元素

article元素最容易跟section和div容易混淆,其实article代表一个在文档,页面或者网站中自成一体的内容,其目的是为了让开发者独立开发或重用。
通常article会有一个标题(通常会在header里),会有一个footer页脚

<article><h1>一篇文章</h1><p>文章内容..</p><footer><p><small>版权:html5jscss网所属,作者:小北</small></p></footer>
</article>

1.如果在article内部再嵌套article,那就代表内嵌的article是与它外部的内容有关联。
2.article内部嵌套section:

<article><h1>前端技术</h1><p>前端技术有那些</p><section><h2>CSS</h2><p>样式..</p></section><section><h2>JS</h2><p>脚本</p></section></article>
文章里的章节,一个article里的section实例

因为文章内section部分虽然也是独立的部分,但是它门只能算是组成整体的一部分,从属关系,article是大主体,section是构成这个大主体的一部分。本网站的全部文章都是article嵌套一个个section章节,这样能让浏览器更容易区分各个章节所包括的内容。
3.section内部也可以嵌套article,article,是一个个独立的整体,而section将这些自成一体的article包裹,就组成了一个团体。
4.div就是只是想用来把元素组合或者给它们加样式时使用。

HTML5其他结构元素标签

address代表区块容器,必须是作为联系信息出现,邮编地址、邮件地址等等,一般出现在footer。
h1-h6:作为标题使用,并且依据重要性递减,因为hgroup,section和article的出现,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>, 就是用来做表格不要用来布局

参考

HTML 5的革新——语义化标签(一)
参考

你是如何理解 HTML 语义化的?相关推荐

  1. 如何理解 HTML 语义化

    你是如何理解 HTML 语义化的?(面试) 在了解 HTML 语义化之前,先科普一下下面几个名词: 语义:是语言所蕴含的意义 (语言的含义).简单的说,符号是语言的载体,符号本身没有意义,只有赋予含义 ...

  2. 190320你如何理解 HTML 语义化?

    你如何理解 HTML 语义化? 概要 HTML目标 HTML实现原理 HTML优点 HTML缺点 HTML演进趋势 HTML解决的问题 HTML技术规范 HTML最佳实践 HTML市场应用趋势 小结 ...

  3. 如何理解Web语义化

    HTML是内容的载体. css样式只是定义表现,人可以直观的感受到,而机器无法理解. 语义化:词必达意.其目的:在不依赖样式的情况下,文档结构依旧清晰:且人.搜索引擎通过读取HTML元素便能更好地理解 ...

  4. 【semantic】如何理解 web 语义化?

    http://www.zhihu.com/question/20455165 顾轶灵,百度前端工程师 http://Lync.in 什么是语义化?其实简单说来就是让机器可以读懂内容. 先 随便扯扯.对 ...

  5. 好程序员web前端分享:如何理解web语义化?

    首先,在理解之前,我们需要先了解,什么是语义化.所谓语义化,简单来说,就是能够更清晰,更直观的理解语言所要表达的含义,所谓词必达意就是这个意思.那么在开发过程中的语义化指的是什么呢?就是能够让除了当事 ...

  6. [html] 你对标签语义化的理解是什么?

    [html] 你对标签语义化的理解是什么? 标签语义化的初衷是让正确的标签做正确的事情,但对于人来说,标签的语义除了在 tag 上体现,还可以从 id, class 上体现出来.而每个人对于标签的理解 ...

  7. 深入浅出的web语义化理解

    写目录 前言 一:什么是语义元素? 二:为什么要语义化? 三:常用的语义元素 四:文档结构标签 五:参考 前言 很多面试官会问: 谈谈你对 HTML5语义化标签的理解. 那么本篇博客可以对你理解HTM ...

  8. html语义化的理解是什么,html5语义化,html5的语义化的理解

    家里有个熊孩子,经常会有一些意想不到的事情发生:回家的时候,他会笑呵呵冲过来,大声喊着臭爸爸;你让他把鞋穿上,他会提起鞋子往楼下扔在小孩的世界里,他虽然会说话,但不一定明白其中的意思,不能正确表达;同 ...

  9. 常见的html行级元素及语义,HTML入门之——结构,常用标签及其属性,再加上语义化...

    一,HTML简介(来源HTML百度百科) HTML:超文本标记语言,是指能够包含链接,图片,程序,视频等非文字元素的页面 二,HTML,XML,XHTML之间有什么区别 HTML:超文本标记语言,语法 ...

最新文章

  1. android 系统的切图方式_UI设计切图规范
  2. Mybatis插入MySQL数据库中文乱码
  3. UVA 1151 Buy or Build MST(最小生成树)
  4. boost::math模块计算 Bessel、Neumann 和 Airy 函数的零点的测试程序
  5. Vue项目中使用svg文件
  6. win10浏览器_[系统] win10浏览器上网问题
  7. java main spring_分享通过在java main函数中执行spring的代码
  8. (进阶)LeetCode(338)——比特位计数(JavaScript)
  9. excel删除行闪退_excel打开闪退解决-打开excel自动退出-自动关闭的解决
  10. CN 国家顶级域名(摘自网络)
  11. 《逆向工程核心原理》学习笔记(一):代码逆向技术基础
  12. 13号线ab线规划图_北京地铁13号线将拆分为AB两线
  13. Linux用户不同UID分类区别
  14. 容灾备份概念及实现方式
  15. java统计字数_JAVA 仿 MS word 字数统计
  16. 数据结构-----引论
  17. 基于扩张状态观测器eso扰动补偿和权重因子调节的电流预测控制,相比传统方法,增加了参数鲁棒性
  18. OLE DB error occured. Code 80040E14h. CoInitialize has not been Called. 问题解决
  19. C++程序设计(检测纽扣是否存在缺陷)
  20. 第一范式转化为第二范式_管理学发展的范式转换及其哲学基础

热门文章

  1. vscode 配php环境的正确姿势
  2. 1、python开发环境搭建与基础语法
  3. 革新的教育培训行业,APP是否成为重点
  4. 油烟在线监控系统云平台 油烟环保监测云平台 油烟大数据平台
  5. java网络测速代码_网络测试连通性
  6. CartoonGAN_CVPR_2018为照片卡通化而生的对抗网络论文阅读笔记
  7. 【zz】owt-server:音视频转发示意图
  8. 智久机器人张龙_智久机器人宣布完成数千万元融资:在中小型企业中普及“机器人换人”...
  9. 全球及中国针状焦市场供需竞争状况与投资风险分析报告2022年
  10. 抢占产业数字化先机,德、美、日做出了不同的抉择