<
紫色光传播网
关于我们 | 会员登陆 | 本站服务项目 | 收藏本站 | 留 言 薄
联系方式:QQ:276016898 电话:(0773)-2182627 (0)13507730004 EMAIL:wa#wahaha8.com
 | 服务项目 | 建站知识 | 网站首页 | 资源下载 | 访客留言 | 代理商城 | 网络编程 | 网页制作 | 电影电视 | 小游戏 | 
热门搜索关键字: 模板 | 错误 | 标签 | 采集 | 数据库 | 组件 | 代码 | 特效 | 木马 | 插件 | 虚拟主机
wahaha8.com baidu
栏目导航  
栏目更新推荐  
·CSS样式表层叠(cascade)处理冲突
·学习CSS的10大理由
·关于CSS框架网页设计
·Div+CSS布局入门教程
·初学DIV+CSS应该理解HTML标签的语义
·CSS教程:关于H1的使用技巧
·控制网页文件大小通过精简CSS实现
·通过Dreamweaver学习了解CSS
点击TOP(10)  
  • 此栏目下没有热点文章
  • 图片文章  

    Div+CSS布局入门教程
     
    您现在的位置: 紫色光传播 >> 网页制作 >> CSS教程 >> 正文
    CSS样式表层叠(cascade)处理冲突
    http://www.wahaha8.com 文章来源:www.zsgsoft.cn 点击数: 更新时间:2008-7-10 【字体:



    发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。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)

      看这段代码:

      #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了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。

    | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明
    Copyright 2006-2008 Wahaha8.com, all rights reserved. Designed by wahaha8.com
    桂ICP备05011060号