CSS 层叠(Cascading)指的是某个元素会根据样式规则的优先级来设置某个元素的外观。
层叠样式的优先级主要有三方面:
- 根据样式域判断,是用户代理样式(user agent stylesheet),还是我们自己写的样式;是否存在
!important
标识; - 根据元素样式属性判断,是否是写在元素行内的 style 属性中;
- 根据选择器判断。
用户代理样式是什么?
基本上所有浏览器都有默认的样式,例如 <h1>-<h6>
,<p>
标签都有默认的上边距和下边距,这是由浏览器默认设置的,所以叫用户代理样式。
如果一个元素身上有很多相同的样式规则,那么到底该应用哪一条呢?
首先,浏览器会先判断当前样式是用户代理样式还是我们自己写的样式,这两者中,我们自己写的样式优先级要高,所以如果同一个元素上存在相同的样式规则,我们自己写的会覆盖浏览器默认样式;
然后,判断当前样式规则是否存在 !important
标识,如果存在,说明它的优先级高,则应用该样式;
其次,判断当前样式规则是否是行内样式,如果是行内样式,它的优先级高于其他样式(但是除了有 !important
标识的除外);
然后,根据选择器的优先级来判断,选择器的优先级顺序从大到小是:ID 选择器、类选择器、属性选择器、伪元素选择器、标签选择器;
最后,根据选择器的个数判断,如果 ID 选择器的个数都相同,则判断类选择器的个数,如果又都相同,则判断属性,伪类元素的个数,如果最后得到的优先级一样,则根据代码顺序,后来者居上,后者覆盖前者。
下面是样式层叠的规则,根据优先级大小降序排列:
- 是否是行内样式,并且有
!important
标识; - 是否具有
!important
标识; - 是否具有 ID 选择器;
- 是否具有类选择器;
- 是否具有属性、伪元素选择器;
- 是否具有标签选择器;
- 是否具有通配符选择器;
- 用户代理样式;
- 继承样式。
继承(Inheritance)
继承指的是元素可以通过继承祖先元素的样式给自身,但是并不是所有样式都可以继承。
几乎所有样式属性都可以属性值 inherit
来实现继承祖先元素的样式。
文本可以继承的样式
这些文本属性可以通过继承实现:color,font,font-size,font-weight,font-variant,font-style,font-family,line-height,word-spacing,white-space,letter-spacing,text-transfrom,text-indent,text-align。
其他可继承的样式
列表元素的部分样式可以通过继承实现:list-style,list-style-type,list-style-position,list-style-image。 表格元素的边框属性:border-collapse,border-spacing。
tips:
平时我们在开发中,最好少用 !important
标识和 ID 选择器,应该它们的优先级很高,如果我们后面想要覆盖他们的样式则必须用相同的方式继续添加 !important
或 ID 来实现,这种方式不利于维护。我们可以通过类选择器、样式层叠规则来覆盖。
参考: 《CSS in Depth》 Keith J. Grant 著