网络编程
位置:首页>> 网络编程>> 网页设计>> CSS的优先级与特殊性

CSS的优先级与特殊性

作者:dudo 来源:dudo blog 发布时间:2008-06-24 11:36:00 

标签:css,样式,优先级,元素

 即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。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了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。

0
投稿

猜你喜欢

  • 1:为什么每个layout下都有个inlayout?我们将layout的宽/浮动等属性设置好之后,对于layout内的padding和mar
  • 经常在网站上看到诸如www.abc.com/?news或者www.abc.com/?id=123这样的网址,一开始觉得很神秘,其实现在看多了
  • 基于很多原因,有不少朋友的空间不支持FSO,当大量的页面生成静态页面时,占用大量的空间,修改样式时,不方便,所以动态页面还是有动态页面的好处
  • 如果你是个赛车手,并且按一下按钮就能够立即更换引擎而不需要把车开到车库里去换,那会是什么感觉呢?MySQL数据库为开发人员所做的就好像是按按
  • 到目前为止,我已经开发了两个HTML编辑器了,一个用在公司的CMS项目,另一个用在这个Blog(TidyEditor,暂时没有单独发布)。下
  • 也许还有朋友不太清楚DOMContentLoaded这个事件。简单的说,这个事件就是要在大多数情况下去替代window.onload事件,因
  • 一、前言:在经过一段时间的存储过程开发之后,写下了一些开发时候的小结和经验与大家共享,希望对大家有益,主要是针对Sybase和SQL Ser
  • caller 属性返回一个对函数的引用,该函数调用了当前函数。functionName.caller functionName 对象是所执行
  • 桥接模式(Bridge Pattern)是什么桥接模式是一种结构型模式,它将抽象部分与实现部分分离开来,使它们可以独立地变化。在桥接模式中,
  • 在上一篇文章中,简单介绍了下闭包(closure)和原型链,现在继续来研究闭包的内部机制。对了,所有的东西都参考自这篇文章:Javascri
  • 需要的软件phpStudy 用来导入一个数据库api-server 数据库功能可以开启一个服务器,让开发环境可以使用生产环境的网址请求安装
  • 1、查看数据库中有哪些用户? select username from all_users;2、查看数据库中有哪些DBA用户? select
  • 本文通过实际业务系统中调整的一个案例,试图给出一个常见CPU消耗问题的一个诊断方法.大多数情况下,系统的性能问题都是由不良SQL代码引起的,
  • 今天因为做一个效果的时候需要CSS的定位来实现,于是我就根据自己原来对CSS的了解,用absolute和relative摆弄了好一阵子,总是
  • 如果备份的数据库有2个文件,分别是.LDF 和 .MDF,打开企业管理器,在实例上右击---所有任务--附加数据库,然后选择那个.MDF文件
  • 前段时间在网上找了一个“完美的”JavaScript对象克隆的函数,感觉还不错,但随后便出现了一些问题,发现这个克隆并不好用,在使用发现了如
  • 如何在线修改表?具体代码如下:<%Set conn1 = Server.CreateObject(&qu
  • set oSQLServer =server.createobject("SQLDMO.SQLServer")oSQLS
  • 在mysql网站时拿到的rpm包只能用root安装,不支持relocate用源码安装后./configure --prefix=/home/
  • 1、修改MD5算法重的4个常数,这是最捷径的作法,其特点是加密后的数据和加密前非常类似,但是不会被破解 2、多次加密,对MD5加密过的数据进
手机版 网络编程 asp之家 www.aspxhome.com