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

CSS样式表
Webjx收集基于CSS+JS设计50款优秀的导航菜单
初学者简单学习CSS网页布局
CSS教程:一张图片实现圆角
基于CSS的网站导航菜单
CSS新特性:圆角边框多栏Gird布局背景设置
CSS实例教程:制作网页特殊产品列表
收集国外网站的25个CSS高级教程
CSS教程:制作圆角矩形的网站头像
网页推荐值得一看的CSS框架
有趣图例:你是一个网页设计师吗?
安装Firefox的Jetpack扩展的步骤
CSS教程:CSS制作3D立方体
Css教程:FireFox正常IE错位的绝对定位元素
CSS对IE6、IE7、IE8支持详细的易用的参考
CSS Sprites简介以及优缺点
CSS教程:避免使用滤镜
DIV+CSS佈局代码精简对SEO的影响
学习CSS需要知道的CSS基础知识
CSS教程:clip属性全知道
基于firebug的firefox扩展:css usage

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 74 ::
收藏到网摘: 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了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。