前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【重构前端知识体系之HTML】讲讲对HTML5的一大特性——语义化的理解

【重构前端知识体系之HTML】讲讲对HTML5的一大特性——语义化的理解

原创
作者头像
归子莫
发布2022-01-19 23:35:32
5020
发布2022-01-19 23:35:32
举报
文章被收录于专栏:归子莫的文章

【重构前端知识体系之HTML】讲讲对HTML5的一大特性——语义化的理解

引言

在讲什么是语义化之前,先看看语义化的背景。

在之前的文章中提到HTML最重要的特性,那就是标签。但是项目一大,标签多的看不懂,一堆叠着一堆。一些命名奇奇怪怪,想维护被劝退,团队协作导致团战开始!

因此语义化迫在眉睫!

什么是语义化

在我们写HTML时其实无所谓,因为你里面长啥样,用户看不到,也不用看到。

因为你有CSS的漂亮衣服,即使你的HTML一塌糊涂,CSS也可以让它光鲜亮丽。

但是用户看不到,开发者看得到呀!因此,这个语义化的友好者是开发者本身。

所谓语义化,就是凭着HTML本身,也能体验出人性化的结构!

语义化的好处

  • 在没有CSS的情况下,页面也能呈现出很好地内容结构、代码结构。这样开发者一眼就明了你的意图,一秒破冰!
  • 对SEO友好。对开发者友好,那么对开发者的小虫子们也是当然! 当标签应用得当,体现出上下文中你想要关键字的权重,那么搜索引擎爬虫就到了你的头上了。那么网站的访问量不就来了吗。
  • 可以支持一些特殊的设备(盲人阅读、移动设备),网页翻译等。
  • 最直观的一点,便是你的队友都希望和你合作!你的代码的语义化,队友都爱啊! 语义化更具可读性,遵循W3C标准的团队都遵循这个标准,可以减少差异化。(跳槽快速融入?)

工作中语义化的思考

  • 不要使用一些纯样式标签,这些CSS会帮我们做到。如:b、font、u等一些标签。
  • 需要强调的文本,可以包含在strong或者em标签中(,strong默认样式是加粗(不要用b),em是斜体(不用i)。使用 mark标签来表示标注的/突出显示的文本。 但是还是可以考虑使用CSS来完成。
  • 每个input标签对应的说明文本都需要使用label标签,并且通过为input设置id属性,在lable标签中设置for=someld来让说明文本和相对应的input关联起来。
  • 表单域要用fieldset标签包起来,并用legend标签说明表单的用途。
  • 应该使用<h1> - <h6>来表示标题。
  • 当用CSS写样式的时候命名也需要遵循HTML的结构,体现出语义化的本质。

语义化的标签

1、<header> 标签定义文档的页眉

通常包含页面的正副标题。

代码语言:javascript
复制
<header>
<h1>他真的是美男子吗?</h1>
<p>据现场勘查,他真的是美男子!</p>
</header>

2、<footer>标签定义文档或节的页脚

页脚通常包含文档的作者、版权信息、使用条款链接、联系信息等等。

可以在一个文档中使用多<footer>元素。

代码语言:javascript
复制
<footer>
  <p>Posted by: 美男子</p>
</footer>

3、<main>标签规定文档的主要内容。

<main>元素中的内容对于文档来说应当是唯一的。

它不应包含在文档中重复出现的内容,比如侧栏、导航栏、版权信息、站点标志或搜索表单。

在一个文档中,不能出现多个 <main> 元素。<main>元素不能是以下元素的后代:<article><aside><footer><header><nav>

代码语言:javascript
复制
<main>
  <h1>我的介绍</h1>
  <p>我是一个聪明的孩子</p>
</main> 

4、<section> 标签定义文档中的片段。

比如章节、页眉、页脚或文档中的其他部分。

代码语言:javascript
复制
<section>
  <h1>PRC</h1>
  <p>The People's Republic of China was born in 1949...</p>
</section>

5、<article> 标签规定独立的自包含内容

比如文章下的评论之类的

代码语言:javascript
复制
<article>
   <h1>我为什么聪明呢</h1>
   <p>我聪明的秘诀是我爱思考</p>
</article>

6、<aside> 标签定义其所处内容之外的内容。

用来装载非正文类的内容。例如广告,成组的链接,侧边栏等等。

代码语言:javascript
复制
<p>聪明的研究</p>
<aside>
  <h1>我为什么聪明呢</h1>
  <p>我聪明的秘诀是我爱思考</p>
</aside>

7、<nav> 元素代表页面的导航链接区域。

用于定义页面的主要导航部分。

代码语言:javascript
复制
<nav>
<ul>
<li><a href=”https://www.baidu.com”>百度</a></li>
<li><a href=”https://www.guizimo.com”>归子莫</a></li>
</ul>
</nav>

一个语义化模板

先来看一张图。

看起来,一个标标致致的HTML结构就很清晰了。

总结

有的朋友肯定会问了,那平时都是用框架写的代码,基本不用用这些,又不是去写个人网站或者官网,都是写一些业务型的H5或者后台管理。

其实对于个人网站或者官网来说,语义化是有实际价值的。而且,这个也是近些年来面试的常问的一题。最重要的是要去学习语义化的含义。做到代码语义化,包括函数的命名,组件的命名,组件业务功能的拆分。一直在路上!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 【重构前端知识体系之HTML】讲讲对HTML5的一大特性——语义化的理解
  • 引言
  • 什么是语义化
  • 语义化的好处
  • 工作中语义化的思考
  • 语义化的标签
  • 一个语义化模板
  • 总结
相关产品与服务
Prowork 团队协同
ProWork 团队协同(以下简称 ProWork )是便捷高效的协同平台,为团队中的不同角色提供支持。团队成员可以通过日历、清单来规划每⽇的工作,同时管理者也可以通过统计报表随时掌握团队状况。ProWork 摒弃了僵化的流程,通过灵活轻量的任务管理体系,满足不同团队的实际情况,目前 ProWork 所有功能均可免费使用。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档