当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > CSS样式表层叠(cascade)处理冲突

CSS样式表
css 块状元素和内联元素
CSS 盒模型、块状元素与内联元素、CSS选择器
css 浮动 理解Float的含义
CSS 清除浮动Clear
CSS 制作网页导航条(上)
CSS 制作网页导航条(下)
css 浮动(float)页面布局
css 浮动(float)页面布局(下)
css position 定位
css 定位应用实例
CSS Hack 有关浏览器兼容方面
css 单图片按钮实例(css 图片变换)
使用X-UA-Compatible来设置IE浏览器兼容模式
div overflow 超出隐藏属性使用说明
CSS 使用规则总结
div+CSS 兼容小摘
CSS的inherit与auto使用分析
如何组织和注释CSS文件
CSS样式按整洁易懂的结构组织
CSS Prism 查看和编辑CSS中用到的颜色

CSS样式表层叠(cascade)处理冲突


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 59 ::
收藏到网摘: n/a


原文连接:http://www.dudo.org/article.asp?id=252
即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。CSS通过一个叫做层叠(cascade)的过程处理这种冲突。层叠给每个规则分配一个重要程度指数。作者定义的样式具有最高的重要性指数,其次是用户定义的样式。但是为了增强用户的控制能力,用户可以通过为任何规则增加一个!important来提高它的重要性指数,让它的优先级高于任何规则,甚至是比作者的!important还要高。
因此,层叠重要性指数的次序依次为:
        标记为!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)

    看这段代码:
         
    1. #wrap#content{color:blue;}    
    2. #content{color:red;}


         
    1. <divid="wrap">    
    2. <divid="content">thisisatexthere</div>    
    3. </div>    

    4. 最终文本会显示什么样的颜色呢?
      是的,样式覆盖只会发生在具有相同优先级的情况下。这个例子中#wrap #content为200,而#content为100,纵使后设定color:red,也不会覆盖掉先前设定的color:blue;。此外,你可以为#content {color: red;}增加!important来看看效果。
      以上都是在少于10个选择符的情况下,可以把这些数值当作十进制来使用和比较,但是,当选择符超过10个(虽然可能性很小)又会怎么样呢?我们参考一个Eric的例子:
         
    1. .hello{color:red;}/*specificity=10*/    
    2. HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}    
    3. /*specificity=15*/
      这里的10并不是“十”,它仅仅代表是一个烦选择符,所以的它的优先级依然要比 15个类型选择符组成的选择器要高。如果换成十六进制的话,就是这个样子
         
    1. .hello{color:red;}/*specificity=10*/    
    2. HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}    
    3. /*specificity=15*/
      但是问题,如果你再添加两个元素,就又变成了11了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。