CSS选择器的特殊性
在我们为元素添加样式的时候,或多或少会出现一个元素会有几个不同规则的样式。有#id的,有.class,直接标签元素的,还有各种组合起来的选择器。那CSS到底如何解决这些冲突呢,我们这次专门来探讨一下。
CSS也称层叠样式,层叠(cascade)也就是说,将重复定义的样式,先通过重要度的筛选,再通过一定的规则,重新排列覆盖。而这个规则就是,选择器的特殊性。(重要度就不详细说明了,一般认为!important>行内样式>内联样式表>外联样式表>浏览器默认样式)
特殊性
每种选择器都会默认分配一个数值,然后将一个规则的选择器数值相加,计算出其特殊性。
选择器的特殊性有4个等级,a,b,c,d(正常来说,一个规则的选择器应该不会超过10个,这样我们可以转化成以10为基数计算特殊性)
- a:行内样式,那么a = 1 。
- b:ID选择器的总数 。
- c:类、伪类和属性选择器的总数。
- d:类型选择器和伪元素选择器总数。
或许这样说,有点难以理解,我们可以举栗子。
style = "" ------------ 特殊性:1000 #warp #content{} ------------ 特殊性:200 #content .smClass{} ------------ 特殊性:110 div.#content{} ------------ 特殊性:101 #content{} ------------ 特殊性:100 p.class1.class2 ------------ 特殊性:21 p.class1 ------------ 特殊性:11 .class ------------ 特殊性:10 div p{} ------------ 特殊性:2 p{} ------------ 特殊性:1
当然,若一个元素的两套规则特殊性相等,则后定义的规则优先。
通过这样一番描述,相信大家对选择器的特殊性有了一定的了解。所以当出现了一些样式定义却未显示的情况时,要看一下是否有样式覆盖的情况,合理使用样式表选择器的优先级。
大家赶紧动手去试试吧!
(若有不准确或错误的地方,希望大家指出,我会赶紧修改)