关于CSS层叠机制
谈到层叠机制,首先我们要知道什么是声明冲突。
声明冲突有三个条件:①多个选择器选中同一个元素;②声明块里的属性相同;③属性的属性值不同。同时满足这三点时就会产生声明冲突。比如下图html代码:
<div>
<p><span>hello word</span></p>
</div>
他的css文件如下:
span{
color:red;
}
p>span{
color:blue;
}
div>p>span{
color:green;
}
此时就会产生声明冲突。
浏览器只会挑其中一个选择器中的样式来渲染网页,关于如何挑选就是层叠机制的内容。
层叠机制:是一种机制,当发生声明冲突时自动触发,浏览器通过层叠机制解决声明冲突。主要内容为:
1、首先比较样式表的优先级。
样式表的优先级受来源和重要性影响。
来源:作者样式表>浏览器默认样式表
重要性:针对作者样式表而言的,有!important>无重要样式声明
因此作者重要>作者普通>浏览器默认,比如:
<div>
<p>
<span>
<a href="http://www.baidu.com">百度一下</a>
</span>
</p>
</div>
a{
color: green!important;
}
a{
color:red;
}
a标签浏览器默认为蓝色,普通定义了样式为红色,重要样式定义了绿色,因此最终被渲染成绿色。
2.比较特殊性,也叫权重or特指度。
规则:行内样式>ID选择器>类、伪类、属性选择器>元素、伪元素选择器>通配符选择器
当发生声明冲突且他们优先级相同时,我们比较特殊性,通过上述规则,我们对每一个样式会产生一个四元数组(a,b,c,d),其中:
a:行内样式为1,否则为0
b:ID选择器的个数
c:类、伪类、属性选择器的个数
d:元素、伪元素选择器的个数
依次从前往后比,大的胜出,一旦胜出,无需再比较之后的数值。例如:
页面中的一个a元素:
<div class="main">
<div>
<p id="nav">
<span class="home">
<a href="http://www.baidu.com">百度一下</a>
</span>
</p>
</div>
</div>
/*样式1*/
a{
color: green;
}
/*样式2*/
.foo{
color:yellow;
}
/*样式3*/
#bar{
color: red;
}
/*样式4*/
.main>div #nav *.home a:link{
color:pink;
}
样式1: 0,0,0,1;
样式2: 0,0,1,0;
样式3: 0,1,0,0;
样式4: 0,1,3,2;
3. 比较源次序。当优先级和特殊性都一样时,书写顺序上,后写的会覆盖先写的。
以上,就是层叠机制的主要内容。
以下,写几个常见的误区;
误区一:认为ID选择器适用范围最小,因此特殊性最高。这种说法是错的,应该按照“四元数组”法判断。
误区二:
<div id="bar">
<a href="http://www.baidu.com">百度一下</a>
</div>
/*样式1*/
#bar{
color: red;
}
/*样式2*/
a{
color: green;
}
认为a标签最后是红色。这里其实样式1和样式2并没有发生声明冲突,由于浏览器中对a元素有默认的样式,作者样式表也写了对a元素的样式,因此没有发生继承。产生声明冲突的是浏览器的默认样式和作者样式表中的样式2,优先级比较知道样式2胜出,无需比较特殊性。
欢迎补充。
关于CSS层叠机制的更多相关文章
- css考核点整理(二)-css层叠机制
css层叠机制 外边距重叠就是margin-collapse. 在CSS当中,相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的外边距可以结合成一个单独的外边距.这种合并外边距的方式被称为折叠,并且因 ...
- css层叠机制说明
css通过建立与文档的关联而实施效果.文档结构重要性不言而喻,对于建立良好的内容索引.提高可维护性.较好的可访问性:另,利于css选择器选择.继承机制. 概要地讲,层叠机制是处理对文档上应用样式时解决 ...
- 三.CSS层叠机制
概述 层叠就是对样式的层叠.是某种样式在样式表中逐层叠加的过程.让浏览器对某个标签特定属性值的多个来源,最终确定使用那个值.层叠是整个CSS的核心机制. HTML文档样式的来源 1.浏览器默认样式,每 ...
- CSS引用方式及样式层叠机制
CSS引用方式有3种,三种分别为:外部引入.内部引入.行内样式,下面一 一进行介绍. 1.外部引入:CSS代码在一个独立的文件中,HTML通过Link标签引入到页面. 代码格式:<link re ...
- CSS中的样式层叠机制Cascade
CSS中的样式层叠机制Cascade 一.样式冲突 样式冲突是CSS渲染过程要解决的一个关键问题,样式冲突主要由两个原因造成: 元素包含了不同对象所赋予的样式:浏览器.用户.作者.其中,浏览器样式 ...
- 层叠机制和继承的概念以及CSS中选择器的优先级
层叠机制: 一个元素的某个特定的样式属性可能来自行间的style属性.内联样式表或者外部引入的样式表,以及浏览器自定义的样式,还有就是继承自父元素的样式,但是最终只会选择其中的某一个来表示,这个选择的 ...
- CSS层叠
前面的话 层叠样式表CSS最基本的一个特性就是层叠.冲突的声明通过层叠进行排序,由此确定最终的文档表示.而这个过程的核心就是选择器及其相关声明的特殊性.重要性.来源及继承机制.本文将详细介绍CSS层叠 ...
- css层叠规则,优先级算法
前言 层叠样式表CSS最基本的一个特性就是层叠.冲突的声明通过层叠进行排序,由此确定最终的文档表示.而这个过程的核心就是选择器及其相关声明的特殊性.重要性.来源及继承机制.本文将详细介绍CSS层叠 特 ...
- css层叠规则(层叠样式表)
CSS层叠规则: 1.找出所有相关的规则,这些规则都包含与一个给定元素匹配的选择器. 2.按权重(!important)和来源对应用到给定元素的所有声明进行排序. 3.按特殊性对应用到给定元素的所有声 ...
随机推荐
- 【CPU微架构设计】分布式多端口(4写2读)寄存器堆设计
寄存器堆(Register File)是微处理的关键部件之一.寄存器堆往往具有多个读写端口,其中写端口往往与多个处理单元相对应.传统的方法是使用集中式寄存器堆,即一个集中式寄存器堆匹配N个处理单元.随 ...
- ExpandableListView解析JSON数据
效果图: 说明:刚开始使用这个控件我花费了3天的时间,但是一直都没有达到预期的效果,要么就是直接全部不显示,要么就是数据累加 ...
- 使用css3实现动画来开启GPU加速
参考文章: https://www.w3cplus.com/css3/introduction-to-hardware-acceleration-css-animations.html http:// ...
- vim matchit 自定义配对关键字之间的跳转
vim因其强大的扩展性一直深受linux程序员的喜爱,最近在用vim写verilog的时候,由于一个逻辑块中的begin end较多,常常会多写或者漏掉匹配关键字,很是苦恼,于是寻找匹配关键字间跳转的 ...
- Month format:number to English abbre
``` DATA LV_MONTH TYPE FCKTX. CLEAR:LV_MONTH,lv_date. SELECT SINGLE KTX INTO LV_MONTH FROM T247 WHER ...
- Integer 函数传参实现值交换
import java.lang.reflect.Field; public class MainClass { public static void main(String[] args) { In ...
- python入门day02数据类型
字符串:数据类型的学习 #======================================基本使用====================================== #1.用途 ...
- gulp打包普通项目
第一步:npm init 生成一个page.json第二步建立一个gulpfile.js文件主要是写这个文件 var gulp = require('gulp'), rev = require('gu ...
- java 爬坑记-@WebServlet异步 不支持@Autowired
上篇文章解决了500那个错误, 程序能接受到request ,进行到调用service 服务时,提示线程空指针异常, 检查发现 //@Autowired //OpHistoryService ophi ...
- 每天写两个的java常见面试题—final 和static 的用法
第一次写随笔,可能写的比较乱,更多的是作为自己记忆一些知识的方式.所有记录的东西都是自己的一些理解,很多语言可能还是从其他大牛的博客里面搬过来的. 一.static的作用: static的的作用从三个 ...