注册本站  论坛  繁體中文

慧民电脑芯片级维修-电脑技巧
手机 | MP3 | MP4 | 显卡 | 主板 | 显示器 | 光存储 | 笔记本 | 网络设备 | 移动存储 | 数码相机
键鼠 | CPU | 音箱 | GPS | 电视 | 服务器 | 投影机 | 机箱电源 | 品牌电脑 | 办公打印 |
| 网站首页 | Cisco | Windows | Linux | Java | Dotnet | Oracle | 网页设计 | 平面设计 | 安全 | 软件应用 | 电脑维修 | 办公维修 |
您现在的位置: 电脑技巧 >> 网页设计 >> HTML >> 网页设计正文

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

文章来源:中国IT实验室收集整理 作者:佚名 更新时间:2008-9-22 12:49:09 【 】 【加入收藏
  进入网络咨询平台

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

  • 上一篇网页设计:

  • 下一篇网页设计:
  • 最 新 热 门
     最简单的“开始”菜单效果
     geom加bitmapdata类打造超酷鼠标跟随效果
     AS3:图像裁剪
     Flash打造小球的弹性碰撞
     as3运用:点击图片取色
     as制作:可拖动单元格的菜单
     利用BitmapData类制作FLASH 3D相册
     使用Flash MX过程中的3个小技巧
     使用AS3自带函数进2/8/10/16/32进制互换
     flash制作字母变换效果
    最 新 推 荐
     13种常用按钮、文本框、表单等CSS样式
     CSS制作很漂亮的文字滑动效果
     用CSS改变的图片由模糊到清楚的导航
     用Class组合实现Div+CSS布局
     css布局实例:网页布局的方法
     CSS实战:美化段落文本之首字下沉
     几个经典的css技巧
     用CSS控制浏览器滚动条样式源代码
     最好的CSS资源
     危险,你敢点击吗?
    相 关 文 章

    Flash CS3教程:绘制小奶瓶图标
    13种常用按钮、文本框、表单等CSS样式
    CSS制作很漂亮的文字滑动效果
    用CSS改变的图片由模糊到清楚的导航
    用Class组合实现Div+CSS布局
    css布局实例:网页布局的方法
    CSS实战:美化段落文本之首字下沉
    几个经典的css技巧
    用CSS控制浏览器滚动条样式源代码
    最好的CSS资源

    | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告

     

    Copyright 2006-2008 pcjx.com All Rights Reserved
    电脑技巧 版权所有 粤ICP备06059145号 地图
    门市地址:广东省佛山市南海区黄岐黄海路133号
    本网站所有内容未经许可不得转载或做其他使用