CSS中的选择器权重
Hello,欢迎来到我的博客,每天一道面试题,我们共同进步。
不用说,CSS权重肯定是面试中最常考的题之一。
我们直接上权重计算规则:
!important
,是觉得的大佬,排第一。补充知识: 1、伪类: 类似于:
:first-child
,last-of-type
这称之为伪类。 CSS3给出定义: The pseudo-class concept is introduced to permit selection based on information that lies outside of the document tree or that cannot be expressed using the other simple selectors. 【伪类存在的意义是为了通过选择器,格式化DOM树以外的信息以及不能被常规CSS选择器获取到的信息。】 2、伪元素: 类似于:::before
,::after
,::selection
,::first-line
,::first-letter
【直观区别是他两:
个数不同】 CSS3给出定义: Pseudo-elements create abstractions about the document tree beyond those specified by the document language. For instance, document languages do not offer mechanisms to access the first letter or first line of an element's content. Pseudo-elements allow authors to refer to this otherwise inaccessible information. Pseudo-elements may also provide authors a way to refer to content that does not exist in the source document (e.g., the ::before and ::after pseudo-elements give access to generated content). 【伪元素可以创建一些文档语言无法创建的虚拟元素。比如:文档语言没有一种机制可以描述元素内容的第一个字母或第一行,但伪元素可以做到(::first-letter、::first-line
)。同时,伪元素还可以创建源文档不存在的内容,比如使用::before
或::after
。】
!important
和内联样式style
都属于不讲理的那种,
!important
,!important
便具有最高优先级;!important
,存在style
,那么style
便具有最高优先级;其余某个选择的权重,就是他们有的选择器的权重相加,相同的话后面的覆盖前面的。
比如:
* /* a=0 b=0 c=0 -> specificity = 0-0-0-0 */
LI /* a=0 b=0 c=1 -> specificity = 0-0-0-1 */
UL LI /* a=0 b=0 c=2 -> specificity = 0-0-0-2 */
UL OL+LI /* a=0 b=0 c=3 -> specificity = 0-0-0-3 */
H1 + *[REL=up] /* a=0 b=1 c=1 -> specificity = 0-0-1-1 */
UL OL LI.red /* a=0 b=1 c=3 -> specificity = 0-0-1-3 */
LI.red.level /* a=0 b=2 c=1 -> specificity = 0-0-2-1 */
#x34y /* a=1 b=0 c=0 -> specificity = 0-1-0-0 */
#s12:not(FOO) /* a=1 b=0 c=1 -> specificity = 0-1-0-1 */