CSS-层叠样式比较(样式冲突的取舍)

文章讲述了在CSS开发中如何处理样式声明冲突。浏览器通过比较重要性(如!important的权重)、特殊性(选择器的范围和数量)以及源次序(代码编写顺序)来确定样式优先级。具体比较规则包括内联样式、ID选择器、类和伪类选择器、元素选择器的权重计算,并强调了!important的最高优先级。
摘要由CSDN通过智能技术生成


以上面的截图为例,在实际的开发过程中随处可见同一个样式被多次应用到同一个元素当中产生的声明冲突。

为了解决样式的声明冲突,浏览器会通过权重计算进行处理。

比较过程

1.比较重要性

作者样式表:开发者书写的样式

1.作者样式表中的 !important 样式
2.作者样式表中的普通样式
3.浏览器默认样式表中的样式
例1
从上图可以看出即使我的 类选择器的优先级高于元素选择器(在第2点会指出),但由于有 !important ,优先级还是最高

2.比较特殊性(看选择器)

总体规则:选择器选中的范围越窄,越特殊

简单的理解 就是我选择器选中的范围越小则优先级越高


由于 类选择器".green" 选中的的范围比 元素选择器"p" 选中的范围更小,所以优先级更高。

具体规则:通过选择器分别计算出4位数字进行比较

  • 第一位:如果是内联样式,记1,否则记0
  • 第二位:选择器中所有id选择器的数量
  • 第三位:选择器中所有类选择器、属性选择器、伪类选择器的数量
  • 第四位:选择器中所有元素选择器,伪元素选择器的数量

由于这个在文章中不好演示,所以我去MDN官方文档中扒了一张图,可以理解下图为从第二、三、四位数字的计算

计算出这4位数字后会按顺序进行比较(比如说第一位值相同才比较第二位)

3.比较源次序(资源/代码顺序)

可以理解为后面的规则覆盖前面的规则,直到最后一个开始设置样式。(最后书写的代码胜出)

注意:比较顺序会依次进行,多个样式比较时,当比较第1点胜出则不会进行后续比较,当第1点比较一致则会进行第2点比较,依次类推

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值