html5中文学习网

您的位置: 首页 > 网页制作 > css教程 » 正文

CSS层叠样式表的层叠是什么意思(自我理解)_CSS教程_CSS_网页制作

[ ] 已经帮助:人解决问题
点评:基本上层叠的意思就是“继承”、“权重”、“覆盖”,通过良好的层级命名更好的实现效果,更少的代码,更多的功能,下面为大家详细介绍下,感兴趣的朋友不要错过

解答一:G5ZHTML5中文学习网 - HTML5先行者学习网

层叠指的是样式的优先级,当产生冲突时以优先级高的为准。G5ZHTML5中文学习网 - HTML5先行者学习网
1. 开发者样式>读者样式>浏览器样式(除非使用!important标记 )G5ZHTML5中文学习网 - HTML5先行者学习网
2. id选择符>(伪)类选择符>元素选择符G5ZHTML5中文学习网 - HTML5先行者学习网
3. 权重相同时取后面定义的样式G5ZHTML5中文学习网 - HTML5先行者学习网

以下是一段经典的html,三个类名分别为模块、标题和正文。G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="mod">G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="hd"></div>G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="bd"></div>G5ZHTML5中文学习网 - HTML5先行者学习网
</div>G5ZHTML5中文学习网 - HTML5先行者学习网
大部分html页面都可以由这种结构嵌套或者累加而成。G5ZHTML5中文学习网 - HTML5先行者学习网

解答二:G5ZHTML5中文学习网 - HTML5先行者学习网

CSS层叠是指CSS样式在针对同一元素配置同一属性时,依据层叠规则(权重)来处理冲突,选择应用权重高的CSS选择器所指定的属性,一般也被描述为权重高的覆盖权重低的,因此也称作层叠。每个CSS选择器都会有一个权重(行内1000,id100,class10,tag1、可以这样认为),当两个选择器同时配置同一元素的同一属性时(比如一个设置color:red,另一个color:black),就会产生冲突,而解决冲突的方案就是CSS选择器的权重,权重高的来覆盖权重低的。G5ZHTML5中文学习网 - HTML5先行者学习网

另外,继承的属性是权重重最轻的,会被上面的四个定义方式覆盖。G5ZHTML5中文学习网 - HTML5先行者学习网

CSS语义化其实更多地是指HTML的语义化。 比如下面的一个代码我们这样写:G5ZHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="box">G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="h2">这是区块标题</div>G5ZHTML5中文学习网 - HTML5先行者学习网
<div class="bd">这是区块内容</div>G5ZHTML5中文学习网 - HTML5先行者学习网
<div> G5ZHTML5中文学习网 - HTML5先行者学习网
G5ZHTML5中文学习网 - HTML5先行者学习网
但是语义化的写法更能使得 robot识别网页的结构,下面是语义化的写法:G5ZHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
G5ZHTML5中文学习网 - HTML5先行者学习网
<section>G5ZHTML5中文学习网 - HTML5先行者学习网
<h2>这是区块标题</h2>G5ZHTML5中文学习网 - HTML5先行者学习网
<p>这是区块内容</p>G5ZHTML5中文学习网 - HTML5先行者学习网
</section>G5ZHTML5中文学习网 - HTML5先行者学习网
G5ZHTML5中文学习网 - HTML5先行者学习网
对于robot来说,它能够识别section(区块)、h2(二级标题)、p(文字段落),但是不能识别出div所包含的内容,因为div这个标记本身是无语义的(必要时通过class或id属性来赋予语义,但是这是次优选择)。 而HTML5新增的article、header、footer、nav、section等标签就是丰富了HTML原生的语义标签,在很大程度上满足了HTML编写的需要。G5ZHTML5中文学习网 - HTML5先行者学习网

解答三:G5ZHTML5中文学习网 - HTML5先行者学习网

我的理解是,层叠指的是上级标签的样式会自动继承到其所有下级标签,如针对<body>设置的标签选择器所设的字体样式会自动应用到<body>下的<p>中,除非<p>重写了相关样式将其覆盖。G5ZHTML5中文学习网 - HTML5先行者学习网
CSS语义化的命名是指用易于理解的名称对html标签附加的class或id命名,如对于页面上方的<div>,可将其id设为header;页面下方的<div>设为footer,可以增强CSS的可维护性。G5ZHTML5中文学习网 - HTML5先行者学习网

基本上层叠的意思就是“继承”、“权重”、“覆盖”,通过良好的层级命名更好的实现效果,更少的代码,更多的功能G5ZHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助