当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > CSS写法:不同组合间的优先级及浏览器的支持性

CSS样式表
CSS网页设计 IE8和IE7共存
CSS2 打印属性让打印HTML文档不出问题
制作网页中设计段落缩进的方法
CSS border 属性使用说明
CSS border-style 属性使用方法
CSS border-color 属性使用方法
CSS border-width 属性使用教程
CSS padding属性定义边内补白
CSS margin 属性定义边外补白
网页布局教程 掌握CSS网页布局属性
css 背景样式属性说明
span margin 设置生效
html 滚动条在IE6和IE7中兼容性问题
IE6 两个div有间隙的问题(IE 3px bug)
CSS 数字和字母将容器撑大问题解决
换个角度看页面重构中的语义化
DIY属于个人开发使用的CSS Reset
CSS 空格引起网页布局间距问题
CSS 网页制作时遇到问题的快速参考技巧
css li 去掉点的样式写法

CSS样式表 中的 CSS写法:不同组合间的优先级及浏览器的支持性


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-03   浏览: 87 ::
收藏到网摘: n/a

这下子彻底土了,昨天乱寻思,结果俺发现的问题令一大群人跟着土了个稀里糊涂。

先来看一段入门级的简单代码:

<div id="box" class="haha wowo gaga"></div>

这段代码代表一个ID为"box",拥有三个class属性(分别是"haha"、"wowo"、"gaga") 的DIV标签。

现在我想设置这个DIV层的宽度和高度都是300像素,背景色为绿色。我们可以这么设置:

对ID进行设置:
#box {
 height: 300px;
 width: 300px;
 background:#336600
}

或者类里面选一个进行设置,如:
.haha {
 height: 300px;
 width: 300px;
 background:#336600
}

OK,我知道现在肯定有人想骂我,说我写这东西是在侮辱大家的智商。但,且慢,似乎这么写也不为错——

.haha.wowo.gaga {
 height: 300px;
 width: 300px;
 background:#336600
}

或者
#box.haha.wowo.gaga {
 height: 300px;
 width: 300px;
 background:#336600
}

看清楚了,选择符之间没空格也没什么英文标点逗号。测试浏览器环境为IE6(IETester模拟)、IE7、Firefox 3.5.3、Chrome 4、Safari 4。

你之前见过这写法?真见过?确认?? ~ OK,要是没见过,来我们这边站队吧,我们一样土。

OK,进一步研究下,首先确认是否复合W3C标准。

在线验证下,结果是通过CSS 2.1 效验。

1

2

接下来,看看还有哪些组合、优先级及兼容性。

首先实验选择符间的组合,XHTML代码依然如上。ID值我们使用"id"代替,三个class属性我们使用"class1"、"class2"、"class3"代替。

组合/浏览器支持
IE6
IE7
Chrome
Firefox
Safari
单id
单class
class间任意组合
(如.class1.class2、
.class1.class2.class3)
id与class间任意组合
(如#id.class1.class2
#id.class1.class2.class3)

OK,再来看下不同组合间的优先级及浏览器的支持性。

组合优先级/浏览器支持
IE6
IE7
Chrome
Firefox
Safari
同元素内
class间组合
数量决定优先级
如.class1.class2 > .class1
X
同元素内
id、class间组合
数量决定优先级
如#id.class1.class2 > #id .class1
X
同元素内
id大于class间任意组合
如#id > .class1.class2.class3
同元素内
id、class组合大于单独id、class
如#id.class1 > #id

 

得了,就土到这了。