您的位置: 首页 > 技术文档 > 网页制作 > 条件CSS的高级用法
手工打造分离式滑动门导航菜单 回到列表 条件CSS的使用
 条件CSS的高级用法

作者:糖伴西红柿 时间: 2009-03-13 文档类型:原创 来自:前端观察


条件CSS的高级用法 [2]

介绍

条件CSS(Conditional-CSS)的开发源于在多数浏览器上修正 CSS 渲染 bug 的需求,以确保尽量多的用户看到正确的网站设计。核心思想建立在 Internet Explorer 上发现的 条件注释 方法,并扩展到包含其他的浏览器,而且将条件声明内联到 CSS 定义里面。

条件CSS(Conditional-CSS)并不仅仅对用户使用的浏览器感兴趣,而是对用户浏览器使用的渲染引擎更感兴趣。这就是条件(Conditional-CSS)使用 ‘Geckko’ 而非广为所知的 Firefox 作为它浏览器条件之一的原因。同样地, ‘Webkit’ 代替了 Safari。这使得其他使用同样渲染引擎地浏览器接受到那些同样地定位 CSS。这个规则地一个例外是使用了 IE(而不是 ‘Trident’),因为这是使用的 IE 的条件注释,而 ‘Trident’ 并不怎么为人所知。同样地,对于 Opera,因为只有 Opera 使用 Presto 渲染引擎,所以使用了 ‘Opera’。

需要注意的是,如果所有浏览器都能正确地执行 W3C 发布的 CSS 标准,那么条件CSS(Conditional-CSS)就没有需求了。但是,CSS bug 对于开发者是无法回避的现实,而且往往都及其让人沮丧。条件CSS(Conditional-CSS)给我们提供了一个简单的方法来解决这些问题。

高级条件声明

条件块

一个典型的条件声明只应用于一条 CSS 规则。当然,也有可能对整个 CSS 块使用条件,这样的块只用于特定的浏览器。下面的例子中 CSS 块只用于 IE 浏览器。

// 条件块实例 
 
[if IE] .box {  
    width: 500px;  
    padding: 100px 0;  
}

一个更高级的使用了条件CSS(Conditional-CSS)的实例样式表可以看 这里。它展示了使用条件声明的各种方法。需要注意的是在条件声明和 CSS 声明之间不需要空格。

条件导入

条件CSS(Conditional-CSS)不仅仅自动将 CSS 中找到的任意 ‘@import’ 声明进行扩展并引入(为了减少 HTTP 请求),也允许条件导入语句。这可以用于为特定浏览器引入一些规则。下面的例子会为移动版 Safari(iPhone / iPod Touch)导入一个样式表,为其他浏览器导入另一个不同的样式表。

// 条件导入实例
 
[if SafMob] @import('iphone.css');  
[if ! SafMob] @import('non-iphone.css');

浏览器分组

将浏览器按照若干支持级别进行分组是一种常见并且是很好的做法。一个由我们在U4EA中提供的 浏览器列表 展示了这中方法,在那里我们将浏览器分成4个不同的支持级别:

  • A 级: 最高级,支持所有组件
  • C 级: 核心支持,基本显示信息
  • X 级: CSS 在该类浏览器中被锁定,仅依赖HTML渲染
  • U 级: 不支持。获得的CSS将和C级浏览器一样

可能遇到的情况是,你只想让A级浏览器获取某些CSS,而又要确保C级以及更低级的浏览器不能看到它们。比如,想让A级浏览器将一个UL列表显示为tab,而其他浏览器按照原始格式显示点式列表。

条件CSS 允许你通过定义一组浏览器到特定的分组来实现此类需求,然后使用标准条件语句中的浏览器区域来匹配这个浏览器分组。条件CSS 有一套内置的标准浏览器分组(当然,你也可以定义你自己的分组):

‘cssA’ - A 级CSS支持

  • IE 6+
  • Gecko 1.0+ (Firefox, Camino, Flock, etc)
  • Webkit 312+ (Safari 1.3+, Google Chrome)
  • Opera 7+
  • Konqueror 3.3+

‘cssX’ - X 级CSS支持

  • IE 4 以下
  • IE Mac 4.5 以下

一个使用条件CSS的浏览器分组的例子:

// 条件CSS浏览器分组实例
[if cssA] ul.li {
 display: block;
 margin-left: 5px;
 width: 50px;
 /* etc */
}

正如你可以看到的,浏览器分组的条件语句被格式化为与标准条件语句同样的语法。注意’cssX’是一个特殊的浏览器分组,它可以引起条件CSS返回空值除了它自己默认的。

  • [if {!} browser_group]

在这里:

  • ! - 代表否定声明(i.e. NOT) - 可选择的
  • browser_group - 指定浏览器分组声明标签
    • ‘cssA’ - A 级浏览器

出处:前端观察
责任编辑:bluehearts

上一页 下一页 条件CSS的高级用法 [2]

◎进入论坛网页制作WEB标准化版块参加讨论,我还想发表评论

相关文章 更多相关链接
手工打造分离式滑动门导航菜单
条件CSS的使用
条件CSS的介绍
跨浏览器的inline-block
超过宽度显示省略号(无js全兼容)
作者文章
条件CSS的使用
跨浏览器的inline-block
CSS实现垂直居中的5种方法
热门搜索:CSS Fireworks 设计比赛 网页制作 web标准 用户体验 UE photoshop Dreamweaver Studio8 Flash 手绘 CG
站点最新 站点最新列表
在网页设计中使用图标来支持内容
《Connection》第8期免费下载
NewWebPick第20期免费中文版
《良木》4期免费下载
手工打造分离式滑动门导航菜单
英特尔酷睿i7新锐100
条件CSS的高级用法
探讨链接打开方式
制作Google Chrome浏览器LOGO
浅析"Rich"设计模式
栏目最新 栏目最新列表
火星人的耳机
公司正式宣布创业失败
用corelDEAW 12打造唇膏
二行代码解决全部网页木马
一行代码解决iframe挂马
Photoshop制作星空爆炸效果
CorelDraw 12打造休闲裤
Firework如何画特殊的切角图形
Firework打造韩式风格的手提袋
flash实例:打造佛光效果
>> 分页 首页 前页 后页 尾页 页次:1/21个记录/页 转到 页 共2个记录

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

本文总共有 6 条评论,现在显示最新的 5 条。评分:- llllllllllllllllllll + 评分人数: 3 ,平均分: 4.33


weihua22 Publish at 2009-3-26 17:34:13
这个条件需要服务器端代码支持,个人认为只要你对浏览器及CSS够了解,有很多兼容问题都可以避开。
weiranner Publish at 2009-3-25 0:52:05 评分3
hao
zhaoliancheng Publish at 2009-3-17 13:12:43
太高级了 我还看不懂
primates Publish at 2009-3-16 18:14:45 评分5
文章是好文章,受益匪浅。评分5分。
现实是残酷的,快节奏的今天,如此细致的融合各个浏览器的技术,却有点让人感到是技术的“倒退”、反潮流……老板一再喊着:应用开发、应用开发……没几个人能静心做到:仔细研究、仔细研究……
zeroWq Publish at 2009-3-15 22:51:46
浏览器大战快点停止吧,如果只有一个浏览器,哪怕是性能最烂,bug最多的IE6,网页重构也不会像现在这么累,

这么说有点泄气,不过假设IE没了,其它浏览器平分天下,虽然标准支持都很好,但是谁能保证各家浏览器不会私有属性泛滥,到时候未必会天下太平

查看全部评论

您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
《Web标准设计》
《美工神话》
《Flash短片轻松学》
Illustrator CS3质感绘画表现技法
大师之路--Photoshop 完全解析
《用户体验要素》
HTML与CSS入门经典(第7版)
作品集 更多内容