用合理的HTML标记以及特有的属性去格式化文档内容。

浏览器会根据标签的语义给定一个默认的样式。

判断网页标签语义是否良好的一个简单方法就是:去掉样式,看网页结构是否组织良好有序,是否仍然有很好的可读性。语义良好的网页去掉样式后结构依然很清晰。

一个语义良好的页面,h标签应该是完整有序没有断层的。

标题与内容

标题和内容模块如下图所示。

这种标题配内容的模块。我们可以用如下几种方案来实现同样的效果

方案一

<div class="h2">标签的语义<a href="#">更多 &gt;&gt;</a></div>
<div class="p">
HTML才是最重要的...修饰结构的。<span class="strong">正确地做法是先确定HTML</span>,确定语义化的标签,再来选用合适的CSS
</div>
<div class="p">
判断网页标...简单方法就是:<span class="strong">去掉样式</span>,看网页结构是否组...结构依然很清晰。一个语义良好的页面,<span class="strong">h标签应...有断层的</span>。
</div>
.h2 { position: relative; border-bottom: 1px dashed #222; }
.h2 a { position: absolute; right: 0; top: 0; }
.p { text-indent: 2em; line-height: 150%; margin-top: 20px; }
.strong { color: red; }

视觉效果达到了,再来看看它的语义吧。我们只能看到‘分隔’ div、‘范围’span这样的无语义标签,从标签上看不出结构的逻辑。这显然是不行的,我们需要用标签代码能够清晰地透露出“标题”,“内容”,“被强调的文本”等信息。

方案二

<h2>标签的语义<a href="#">更多 &gt;&gt;</a></h2>
<p>HTML才是最...来修饰结构的。<strong>正确地做法是先确定HTML</strong>,确定语义化的标签,再来选用合适的CSS</p>
<p>判断网页标签语...简单方法就是:<strong>去掉样式</strong>
一个语义良好的页面,<strong>h标签应该是完整有序没有断层的</strong>。</p>
h2 { position: relative; border-bottom: 1px dashed #222; }
h2 a { position: absolute; right: 0; top: 0; }
p { text-indent: 2em; line-height: 150%; margin-top: 20px; }
strong { color: red; }

方案二大有改进,从标签中能清楚地看到标题和内容的划分,也能看到“根据浏览器的默认样式”被强调了。但还有要改进的地方<h2>标签的语义<a href="#">更多 &gt;&gt;</a></h2>,更多信息它不应属于二级标题的,虽然视觉上它和“标签语义”是放在同一行的,但事实上它并不属于标题!让我们再改进一下。

方案三

<h2>标签的语义</h2>
<a href="#">更多 &gt;&gt;</a>
<p>HTML才是最...来修饰结构的。<strong>正确地做法是先确定HTML</strong>,确定语义化的标签,再来选用合适的CSS</p>
<p>判断网页标签语...简单方法就是:<strong>去掉样式</strong>
一个语义良好的页面,<strong>h标签应该是完整有序没有断层的</strong>。</p>

此时语义是不错了,但根据方案三的HTML结构,我们很难通过CSS完成设计图中的设计。于是要借助无语义化的div和span了。

<div class="header">
<h2>标签的语义</h2>
<a href="#">更多 &gt;&gt;</a></div>
<p>HTML才是最...来修饰结构的。<strong>正确地做法是先确定HTML</strong>,确定语义化的标签,再来选用合适的CSS</p>
<p>判断网页标签语...简单方法就是:<strong>去掉样式</strong>
一个语义良好的页面,<strong>h标签应该是完整有序没有断层的</strong>。</p>

添加适当的无语义标签div和span,这样我们的代码既精简,语义又清晰。这里需要特别说明的是,当页面内标签无法满足设计需要时,才适当添加div和span等无语义标签来辅助实现。

语义化标签应注意的其他问题

1. 尽可能少地使用无语义化标签div和span

2. 在语义不明显,既可以用p也可以用div的地方,尽量用p,因为p默认情况下有上下间距,去样式后的可读性更好,对兼容特殊终端有利;

3. 语义上需要强调的文本可以包在strong或em标签里,strong和em有”强调”的语义,其中strong的默认样式是加粗,而em的默认样式是斜体。

更新2013-08-12

为什么要语义化

1. 手持移动设备的无障碍阅读

手持移动设备可能对CSS的解析能力较弱,这时可能就需要更语义化的标签来体现一个页面的易读性

2. 搜索引擎的友好收录

蜘蛛爬行能够根据标签的使用来确定上下和各关键字的权重

3. 盲人等一些障碍人士的更好地阅读

4. 技术趋势所需

正如HTML初衷那样,各个标签的本义就是希望在特定的地方使用合适的标签,而不是去用样式来表现一个不语义的标签。

5. 便于团队醒目的可持续运用及维护

语义化的命名能够使我们在多人协作一个项目时更加有序和快捷。

HTML语义化之常见模块的更多相关文章

  1. 第二天学习笔记:(MDN HTML学习、web安全策略与常见攻击、语义化)

    一:Web入门 1:web文件命名 在文件名中应使用连字符(-).搜索引擎把连字符当作一个词的分隔符, 但不会以这种方式处理下划线. 养成在文件夹和文件名中使用小写,并且使用短横线而不是空格来分隔的习 ...

  2. 浏览器中常见的html语义化标签

    html标签默认在浏览器中展示的样式,html标签的用途:语义化(明白每个标签的用途,在什么情况下使用此标签合理);标签语义化好处:1.更容易被搜索引擎收录2.更容易让屏幕阅读器读出网页内容. 网页上 ...

  3. Semver(语义化版本号)扫盲

    最近Github 10周年在朋友圈里沸沸扬扬刷屏,小编在工作中却惊讶的发现不少同事对版本号中的beta和rc没有概念,使用 npm install package@next 时,也不清楚next代表的 ...

  4. HTML5的新语义化的标签

    在HTML5之前采用HTML+CSS文档结构写法 [ID选择器说明 id选择器——用于标识页面上特定元素(比如站点导航.页眉.页脚)而且必须唯一; 也可以用来标识持久结构性元素(如主导航.内容区域)] ...

  5. 如何让你的JavaScript代码更加语义化

    语义化这个词在 HTML 中用的比较多,即根据内容的结构化选择合适的标签.其作用不容小觑: 赋予标签含义,让代码结构更加清晰,虽然我们可以在标签上添加 class 来标识,但这种通过属性来表示本体的形 ...

  6. Semantic UI – 完全语义化的前端界面开发框架

    Semantic UI 是一个 UI 库,使前端开发更简单,更容易学习.Semantic UI 介绍了许多界面元素.在大多数情况下,只有你需要的元素建立一个自定义的构建可能是最好的. UI 组件分为四 ...

  7. Html5新增的语义化标签(部分)

    2014年10月29日,万维网联盟宣布,经过接近8年的艰苦努力,html5的标准规范终于制定完成.这是互联网的一次重大变革,这也许是一个时代的来临! 总结一些h5新增的语义化标签,记录下来方便自己学习 ...

  8. 腾讯TGideas语义化标签(转)

    --------引子--------------- 家里有个熊孩子,经常会有一些意想不到的事情发生:回家的时候,他会笑呵呵冲过来,大声喊着“臭爸爸”:你让他把鞋穿上,他会提起鞋子往楼下扔...在小孩的 ...

  9. html5语义化标签总结二

    HTML 5的革新之一:语义化标签二文本元素标签.分组元素标签. HTML 5的革新——语义化标签(一)中介绍了一些HTML5新加的一些节元素,一张页面中结构元素构成网页大体,但是也需要其他内容来填充 ...

随机推荐

  1. MyBatis入门(一)---基本使用

    一.MyBatis简介 1.1.概述 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架. MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集. M ...

  2. 基础学习day03---程序结构与控制、函数与数组入门

    一.程序结构   1.顺序结构 2.选择结构 3.循环结构 二.顺序结构 程序至上而下逐行执行,一条语句执行完之后继续执行下一条语句,一直到程序的末尾 三.条件选择结构 选择结构是根据条件的成立与否, ...

  3. iOS 学习 - 5.UILabel设置行距

    NSMutableAttributedString *arrString =[[NSMutableAttributedString alloc]initWithString:@"asdass ...

  4. android学习笔记 activity生命周期&任务栈&activity启动模式

    activity生命周期 完整生命周期 oncreate->onstart->onresume->onpause->onstop->ondestory 使用场景:应用程序 ...

  5. C语言-10-位域与共用体

    位域 在某种特定情况下,一个结构体中的多个变量只使用各自存储空间的几位,而其他位从来不使用.这种情况下,可以使用位域来限定每个变量的用来存储数据的位宽. 作用 限定结构体中变量用来存放数据的位宽,即使 ...

  6. Regex Expression的资料和笔记整理

    维基百科:http://en.wikipedia.org/wiki/Regular_expression 正则表达式在线测试:http://tool.chinaz.com/regex/ 正则表达式,常 ...

  7. Uva 110 - Meta-Loopless Sorts(!循环,回溯!)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

  8. android基础开发之scrollview

    scrollView 是android系统提供的一种 特殊的展示view. 其实我们很早就遇到过scrollview的东东,比如listview. 而google官方文档也提出,不要混合使用scrol ...

  9. MongoDB学习笔记——文档操作之增删改

    插入文档 使用db.COLLECTION_NAME.insert() 或 db.COLLECTION_NAME.save() 方法向集合中插入文档 db.users.insert( { user_id ...

  10. sql server 导出的datetime结果 CAST(0x00009E0E0095524F AS DateTime) 如何向mysql,oracle等数据库进行转换

    1. 处理 sql server 导出的 datetime 类型的字段 在进行sql server向mysql等其他数据进行迁移数据时,会发现使用sql server导出的datetime类型的结果是 ...