当前位置: 首页 > 图文教程 > 网页制作 > 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)   发布: 2009-10-12   浏览: 108 ::
收藏到网摘: n/a

介绍

毫无疑问,任何一个试图使用 CSS 的网页设计师和开发人员都会发现不同的浏览器要求不同的样式声明。这些烦恼归咎于各浏览器及其各版本不同程度的 CSS 执行的完整性。条件 CSS 是这个问题的一个解决方案,采用的是 Internet Explorer 的条件注释语法的思想,并把它内联到 CSS 声明之中。

基本用法

条件 CSS 主要用于指出一个特别的 CSS 声明是不是应该用于一个特别的浏览器。当然你不希望经常这么做,但是当你需要针对一个浏览器的时候,它会非常有用。可以在U4EA支持列表里看到,大部分的浏览器都支持这种方式。

任意 CSS 声明或者块都可以添加条件声明前缀,这些前缀有3种基本类型:

[if {!} browser]

[if {!} browser version]

[if {!} condition browser version]

! - 声明的否定 (例 NOT) - 可选

browser - 声明针对的浏览器

‘IE’ - Internet Explorer

‘Gecko’ - Gecko 核心的浏览器 (Firefox, Camino 等)

‘Webkit’ - Webkit 核心的浏览器 (Safari, Shiira 等)

‘SafMob’ - 移动版 Safari (iPhone / iPod Touch)

‘Opera’ - Opera 的浏览器

‘IEMac’ - Mac 版本的 Internet Explorer

‘Konq’ - Konqueror

‘IEmob’ - 移动版 IE

‘PSP’ - Playstation Portable

‘NetF’ - Net Front(恕糖伴西红柿无知,不知道这是啥东东)

version - 要针对的浏览器版本

condition - 算术符

lt - 小于

lte - 小于等于

eq - 等于

gte - 大于等于

gt - 大于

一些条件声明的例子:

// 条件-CSS 语法实例

[if IE] - 如果浏览器是 IE

[if ! Opera] - 如果浏览器不是 Opera

[if IE 5] - 如果浏览器是 IE 5

[if lte IE 6] - 如果浏览器是 IE 6 或者更低版本 (IE 5, IE 4 等)

[if ! gt IE 6] - 和上面的声明等效, 如果浏览器版本不高于 IE 6

因为许多实例认为 div 是具有 width 和 padding 的盒类。因此它也应该在 IE 5 中表现正常(我发现很多人已经放弃支持 IE 5了,但这是一个经典例子)。IE 5的盒模型不标准,因此这就是使用条件 CSS 解决的方法:

// 条件 CSS 盒模型例子

div.box {

width: 400px;

[if IE 5] width: 600px;

padding: 0 100px;
}

像你所看到的,条件 CSS 使得你可以只维护一个 CSS 文件,而不是好几个需要用到 IE 的条件注释的文件。这有助于流线型维护,也使得代码更加清晰。

再进一步,条件 CSS 的一个重要特性是当它发现一条 @import CSS 声明时,它会自动打开并插入需要导入的文件。这样就减少了页面的加载时间,因为浏览器只需要对 CSS 文件做出一条 HTTP 请求。

尽管条件 CSS 大多用于针对不同版本的 IE 浏览器,当你在别的浏览器碰到很难修正的 bug(主要使用 Javascript 修正) 的时候,条件 CSS 也是相当有用的。例子包括了缺少 ‘display: inline-block’ 支持的 Firefox 2 和 Safari 2 中的 背景图片 bug。这些 bug 在这些浏览器的最新版本里面已经修正了,但是当这些浏览器占有一定市场份额的时候,向后兼容就很重要了。

下面的图片展示了此页面在 IE7,Safari 3,Firefox 2 和 Opera 9 中的显示效果。


注意这个例子不适合部署在实际生产环境中,因为你只想在各浏览器总保持一致的布局,而条件 CSS 只是用来修正 CSS 显示 bug。但是这个例子确实给出了一个好的例子用来说明不同的 CSS 怎样定位不同的浏览器。