打印本文 关闭窗口 | ||||
CSS样式表层叠(cascade)处理冲突 | ||||
作者:陈鹏 文章来源:eNet 点击数 更新时间:2009/9/12 8:46:46 文章录入:陈鹏 责任编辑:陈鹏 | ||||
|
||||
因此,层叠重要性指数的次序依次为: 标记为!important的用户样式 标记为!important的作者样式 作者样式 用户样式 浏览器/用户代理的默认样式 为了计算规则的优先级,每种类型的选择符都有一个相应的数值,由于每个选择器都由若干选择符组成,所以选择器的优先指数由选择符对应的数值相加而成,数值越高,优先级越高。CSS中的选择符有四类: 行内样式(Inline Style),如<span style="color:red">...</span> ID选择符(ID selectors),如#myid 类、属性选择符、伪类(Classes, attributes and pseudo-classes),如 .class {...}、[href$=dudo.org]、:hover 元素(elements)、伪元素选择符(pseudo-elements),如 p {...}、:first-line {...} 怎么来测量呢?如前所述,它们每一类都有不同的数值表示,其中: 行内样式为:1000 ID选择符为:0100 类选择符为:0010 元素样式为:0001 这里要指出的是,所有这些数值都不是10进制数字,1000只是代码它是一个行内样式, 例如,body #wrap p {...},那么它的优先级指数就是 1+100+1=102,而body div#wrap p {...}的优先级指数就是 1+ 1 +100 + 1 =103。 再看一下其它的例子: * { } 0 li:first-line { } 2 (one element, one pseudo-element) ul ol+li { } 3 (three elements) ul ol li.red { } 13 (one class, three elements) style=”” 1000 (one inline styling) div p { } 2 (two HTML selectors) div p.sith { } 12 (two HTML selectors and a class selector) body #darkside .sith p { } 112 (HTML selector, id selector, class selector, HTML selector; 1+100+10+1) 看这段代码: #wrap #content {color: blue;} #content {color: red;} <div id="wrap"> <div id="content">this is a text here</div> </div> 最终文本会显示什么样的颜色呢? 是的,样式覆盖只会发生在具有相同优先级的情况下。这个例子中#wrap #content为200,而#content为100,纵使后设定color:red,也不会覆盖掉先前设定的color:blue;。此外,你可以为#content {color: red;}增加!important来看看效果。 以上都是在少于10个选择符的情况下,可以把这些数值当作十进制来使用和比较,但是,当选择符超过10个(虽然可能性很小)又会怎么样呢?我们参考一个Eric的例子: .hello {color: red;} /* specificity = 10 */ HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;} /* specificity = 15 */ 这里的10并不是“十”,它仅仅代表是一个烦选择符,所以的它的优先级依然要比 15个类型选择符组成的选择器要高。如果换成十六进制的话,就是这个样子 .hello {color: red;} /* specificity = 10 */ HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;} /* specificity = 15 */ 但是问题,如果你再添加两个元素,就又变成了11了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。
|
||||
打印本文 关闭窗口 |