特殊性
选择器的特殊性由选择器本身的组件确定。特殊性值表述为4个部分:0,0,0,0。
比较规则
因为值是从左向右排序的,所有1,0,0,0大于以0开头的所有特殊值,而不论后面的数是什么。比如,0,0,1,0比值0,0,0,13更高。
通配符的特殊性为0,0,0,0.对特殊性没有贡献。
id选择器和id属性的属性选择器特殊值分别为,0,1,0,0,和0,0,1,0.因此id属性的属性选择器比较低。
内敛声明的特殊性为1,0,0,0是最高的。
为内敛样式声明保留一位,这是CSS2.1才新增的,这样做是为了反映写CSS2.1当时的web浏览器表现。在CSS2中,内联样式声明的特殊性是1,0,0(特殊性包含3个值,而不是4个)。它与ID选择器的特殊性相同,所以ID选择器很容易覆盖内联样式。
!import重要性
标志为 !important的声明并没有特殊的特殊值,不过要与非重要的声明分开考虑。实际上,所有!important的声明会分组在一起,重要声明的特殊性冲突会在重要声明内部解决,而不会与非重要声明想混。类似地,我们认为所有非重要声明也归为一组,使用特殊性来解决。如果一个重要声明和一个非重要声明冲突,胜出的总是重要声明。
继承
大多数的和模型设置是不能够继承的。继承的值根本没有特殊性,甚至连0特殊性都没有。而0特殊性要比无特殊性要强。
* {color:gray}h1#page-title {color:black;}Meerkat Central
Welcome to the best place on the web for meerkat information
em里面继承了h1的color,但是由于没有特殊性,所以被特殊性为0,0,0,0的通配符打败。颜色为灰色。
这个例子说明了不加区别的使用通配符选择器可能存在的问题之一。由于它能匹配任何元素,所以通配符选择器往往有一种短路继承的效果。这个问题可以解决,不过通常更合理的做法是从一开始就避免不加区别地使用通配符选择器,从而从根本上避免这个问题。
继承制完全没有特殊性,这一点很关键,决不能等闲视之。例如,架设一个样式表编写如下,使"工具条"中所有的文本都是黑底白字:
#toolbar {color : white;background:black;}
只要id为toolbar的元素只包含纯文本而不包含其他内容,这就能正常起作用。不过如果这个元素的文本都是超链接,用户代理的超链接样式就会占上风。在一个web浏览器中,这意味着他们的颜色很可能是蓝色,因为浏览器的样式表可能包含以下规则:
a:link {color : blue;}
为克服这个问题,必须如下声明:
#toolbar {color : white ; background : black;} #toolbar a:link {color : white;}
层叠
特殊性相等的两个规则同事应用到同一个元素的层叠规则:
正式由于这种顺序排序,所以才有了通常推荐的链接样式顺序。一般建议按照link-visited-hover-active(LVHA)的顺序声明链接样式。
非CSS表现提示
文档有可能包含有非CSS的表现提示,例如font元素。非CSS提示被处理为特殊性为0,并出现在创作人员样式表的最前面。只要有创作人员或者读者样式,这种表现提示就会被覆盖,但是用户代理的样式不能将其覆盖。