CSS选择器的权重计算

什么是CSS选择器权重?

即使在不太复杂的样式表中,要寻找同一元素可能有两个或者更多规则,当同一元素被多个不同来源的样式规则设置了样式后,如何处理样式规则的冲突,显示元素最后的样式,用到的计算规则就是CSS选择器的权重规则。

根据选择器的特殊性决定规则的次序。具有更特殊选择器的规则优先于具有一般选择器的规则。如果两个规则的特殊性相同,那么后定义的规则优先。

特殊性

为了计算规则的特殊性,给每种选择器都分配一个数字值。然后,将规则的每个选择器的值加在一起,计算出规则的特殊性。特殊性的计算不是以10为技术的,而是采用一个更高的未指定的基数。这能确保非常特殊的选择器(比如ID选择器)不会被大量一般选择器(比如类型选择器)所超越。但是,为了简化,如果在一个特定选择器中的选择器数量少于10个,那么可以以10为基数计算特殊性。

选择器的特殊性分成4个成分等级:a, b, c 和 d。

  • 如果样式是行内样式,那么a=1
  • b等于ID选择器的总数
  • c等于类,伪类和属性选择器的数量
  • d等于类型选择器和伪元素选择的数量

使用这些规则可以计算任何CSS选择器的特殊性。下面的表格给出了一系列选择器以及相应的特殊性。

选择器 特殊性 以10为技术的特殊性
Style=" " 1,0,0,0 1000
#wrapper #content {} 0,2,0,0 200
#content .name {} 0,1,1,0 110
div#ontent {} 0,1,0,1 101
#content {} 0,1,0,0 100
p.comment .name {} 0,0,2,1 21
p.comment {} 0,0,1,1 11
div p {} 0,0,0,2 2
p {} 0,0,0,1 1

用style属性编写的规则总是比其他任何规则特殊。具有ID选择器的规则比没有ID选择器的规则特殊,具有类选择器的规则比只有类型选择器的规则特殊。如果两个规则的特殊性相同,那么后定义的规则优先。

原文地址:https://www.cnblogs.com/nanxia/p/8411992.html

时间: 2024-12-06 00:24:18

CSS选择器的权重计算的相关文章

CSS选择器的权重计算规则

我们在使用CSS对网页元素定义样式时经常会遇到这种情况:要对一般元素应用一般样式,然后在更特殊的元素上覆盖它们.那么我们怎么样来保证我们所新定义的元素样式能覆盖目标元素上原有的样式呢? 在CSS中,会根据选择器的特殊性来决定所定义的样式规则的次序,具有更特殊选择器的规则优先于具有一般选择器的规则,如果两个规则的特殊性相同,那么后定义的规则优先. 那么,又怎么来计算选择器的特殊性呢?下面这张图介绍了特殊性的计算方法: 我们把特殊性分为4个等级,每个等级代表一类选择器,每个等级的值为其所代表的选择器

CSS选择器的权重与优先规则

我们在使用CSS对网页元素定义样式时经常会遇到这种情况:要对一般元素应用一般样式,然后在更特殊的元素上覆盖它们.那么我们怎么样来保证我们所新定义的元素样式能覆盖目标元素上原有的样式呢? 在CSS中,会根据选择器的特殊性来决定所定义的样式规则的次序,具有更特殊选择器的规则优先于具有一般选择器的规则,如果两个规则的特殊性相同,那么后定义的规则优先. 那么,又怎么来计算选择器的特殊性呢?下面这张图介绍了特殊性的计算方法: 我们把特殊性分为4个等级,每个等级代表一类选择器,每个等级的值为其所代表的选择器

CSS选择器的权重与优先规则?

我们做项目的时候,经常遇到样式层叠问题,被其他的样式覆盖,或者写的权重不高没效果,对权重没有具体的分析,做了一个总结. css继承是从一个元素向其后代元素传递属性值所采用的机制.确定应当向一个元素应用哪些值时,浏览器不仅要考虑继承,还要考虑声明的特殊性,另外需要考虑声明本身的来源.这个过程就称为层叠.——<css权威指南> 如下图,css规则由选择器和声明块组成,写在选择器后面大括号里的就叫声明. 一.样式类型1.行间 <h1 style="font-size:12px;col

CSS选择器的权重与优先规则(转)

CSS选择器的权重与优先规则在CSS中,会根据选择器的特殊性来决定所定义的样式规则的次序,具有更特殊选择器的规则优先于具有一般选择器的规则,如果两个规则的特殊性相同,那么后定义的规则优先. 从样式选择器看权重优先级:important > 内嵌样式 > ID > 类 > 标签 | 伪类 | 属性选择 > 伪对象 > 继承 > 通配符.important的权重为1000 我们把特殊性分为4个等级,每个等级代表一类选择器,每个等级的值为其所代表的选择器的个数乘以这一等

CSS选择器的权重关系

切记CSS选择器的权重关系,避免在页面中出现CSS样式无法生效的情况~ – 内嵌 id class 元素 – a b c d 内嵌 1 0 0 0 id 0 1 0 0 class.属性.伪类 0 0 1 0 元素.伪元素 0 0 0 1 通配符* 0       !improtant(写在声明中,更改权重值) 最高       a组数值只有把CSS写进style属性时才会为1,否则为0: b组数值决定于ID选择器,有多少ID选择器,并会进行此数组值累加: c组数值决定于类选择器,有多少类选择器

css选择器权重值计算规则

一.样式类型 1.行间 <h1 style="font-size:12px;color:#000;">我的行间CSS样式.</h1> 2.内联 <style type="text/css"> h1{font-size:12px; color:#000; } </style> 3.外部 <link rel="stylesheet" href="css/style.css"&g

css选择器、权重

基础选择器 一.标签选择器 p{...}  h1{…..}   css不区分大小写,建议小写 1.所有的标签都可以作为标签选择器去使用 2.无论这个标签藏多深,一定能够被选上 3.选择页面所有的,而不是具体某一个: 标签选择器,选择的是页面上所有这种类型的标签,所以经常描述“共性”,无法描述某一个元素的“个性”的. 二.id选择器 所有的标签都可以有id属性来标识标签. Id属性的值: 1)只能是数字字母下划线,必须以字母开头 ,不能和标签同名. 2)一个页面中不能出现相同的id,哪怕他们不是一

深入理解CSS选择器优先级的计算

选择器的优先级关系到元素应用哪个样式.在CSS2.1的规范(http://www.w3.org/TR/2009/CR-CSS2-20090908/cascade.html#specificity)中是这样描述的: 如果声明来自于“style”属性,而不是带有选择器的规则,则记为 1,否则记为 0 (= a)(HTML元素的style属性也是样式规则,因为这些样式规则没有选择器,因此记为a=1,b=0,c=0,d=0) 计算选择器中 ID 属性的个数 (= b) 计算选择器中其他属性(类.属性选择

css选择器 及其权重

css选择器: .class,#id,*,element(标签选择器),[attribute] 属性选择器,:first-child(伪类选择器) 权重 !important>行内样式>ID选择器>类选择器|属性选择器|伪类选择器>元素选择器 尽量避免使用!important 覆盖!important <div id="app"> <div class="test" id="test"> <s