您的位置:首页 > Web前端 > CSS

css的特殊性笔记总结

2014-02-02 20:59 141 查看
css 的特殊性也叫做css的权重。

在css的选择器中,不同的选择器有不同的优先权也就是特殊性。选择器的特殊性由选择器本身的组件确定。特殊性值得表述为4个部分,如:0,0,0,0.

(1)对于选择器中给定的各个ID属性值,加0,1,0,0。

(2)对于选择器中给定的各个类属性值、属性选择或伪类,加0,0,1,0。

(3)对于选择器中给定的各个元素和伪类,加0,0,0,1。

(4)结合符合通配符选择器对特殊性没有任何贡献,也即是0,0,0,0。

(5)继承的值根本没有特殊性,也就比0,0,0,0还要低。

css解析时,都是从右到左解析选择器的,最右边的选择器越具体,其效率越高。通常#ID和.class前面不应加累赘的标签,否则影响到效率和权重。

按照权重和来源排序

在声明权重方面要考虑5级。权重由大到小的顺序依次为(重要声明是拥有!important):

(1)读者的重要声明

(2)创作人员的重要声明

(3)创作人员的正常声明

(4)读者的正常声明

(5)用户代理声明

如果两个规则中的权重、来源和特殊性完全相同,那么在样式表中后出现的一个会胜出.

css2.1的层叠规则:

(1)找出所有相关的规则,这些规则都包含与一个给定元素匹配的选择器。

(2)按照显式权重对应用到该元素的所有声明排序。标志!important的规则的权重要高于没有!important标志的规则。

(3)按照来源对应用到给定元素的所有声明排序。共有3种来源,创作人员,读者和用户代理。正常情况下,创作人员 > 读者模式 > 用户代理的默认样式。

(4)按照特殊性对应用到给定元素的所有声明排序。有较高特殊性的元素权重要大于有较低的特殊性的元素。

(5)按照出现的顺序应用到给定元素的所有声明排序。一个声明在样式表或文档中越后出现,它的权重就越大。如果样式表中右导入的样式表,一般认为出现在导入样式表中的声明在前,主样式表中的所有声明在后。

ps:参考《css权威指南》
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: