登录论坛 | 注册会员 设为首页 | 收藏本站
当前位置 : 首页>软件学院>程序开发>CSS>正文
 
CSS样式表层叠(cascade)处理冲突

http://www.dbit.cn 2008-7-11 7:55:44  来源:本站  编辑:叶子
 
  即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。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了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。
 
收藏】【打印】【进入论坛
  相关文章:

·CSS3 Media Queries 详解
·CSS实例教程:非浮动区域设置宽度
·css的效率和浏览器渲染的速度
·关于CSS HACK 解决兼容的写法 
·小议使用“完整”的CSS的缺点
·关于CSS不透明的详细介绍 
·CSS中设置段落间距的方法
·用css网站布局之十步实录
·DIV+CSS布局代码精简对SEO的影响 
·CSS教程:网页中英文字体的设置 
·css3文本阴影属性text-shadow说明 

 
 
 
 
最新文章

中关村艳照门女主角详记录高清组图 
大连护士门大尺度艳照高清组图
iPhone女孩微博爆红 最宝贵东西换iPhon
反恐精英之父内维尔:改变电脑游戏销售
团购网站黎明之前:中国市场惨烈厮杀不
团购鼻祖Groupon中国揭秘:快与慢的商业
Spil Games发布新的品牌形象
1800配置一台主机 不要显示器
联想V360笔记本模特写真
爱国者第四代移动硬盘将面市、低电压保

 
推荐文章
1
2
3
4
5
6
7
8
9
10
iPhone女孩微博爆红 最宝贵东西换
大连护士门大尺度艳照高清组图
中关村艳照门女主角详记录高清组
苹果员工中毒门
宫如敏不雅照疯传 看张馨予韩一菲
深耕市场 永续经营——专访百脑汇
优派专业电子书 让您回家旅途多姿
揭晓百万大奖三星bada魅力绽放中
大明龙权“江湖英雄会”全国PK大
永恒之塔校园达人挑战赛完美落幕
八卦图解 More>>
iPhone女孩微博爆红 最宝贵东西换 大连护士门大尺度艳照高清组图
中关村艳照门女主角详记录高清组 宫如敏不雅照疯传 看张馨予韩一菲