各浏览器 CSS Hack 整理

作者:zhaozy 来源:3user 时间:2008-01-17 10:54:00 

CSS Hack是在标准CSS没办法兼容各浏览器显示效果时才会用上的补救方法,在各浏览器厂商解析CSS没有达成一致前,我们只能用这样的方法来完成这样的任务.

我进行前端开发的时候,测试用的浏览器大致有: IE7, IE6, Opera9(文章撰写时版本为9.25 8825), Safari3(文章撰写时版本为3.0.4 523.15), Firefox2(文章撰写时版本为2.0.0.11).

在正常的 selector { property:value; } 的基础上常会根据具体情况为相同元素使用Hack以达到浏览器间统一.

IE系列:


selector { +property:value; } 在属性名前加上加号"+",这个Hack只有IE系列可以识别. 
selector { *property:value; } 在属性名前加上星号"*",这个Hack只有IE系列可以识别. 
selector { _property:value; } 在属性名前加上下划线"_",这个Hack只有IE系列 (除IE7外) 识别. 
* html selector{ property:value; } 在选择器上运用继承法 * html selector, 这个Hack只有IE系列 (除IE7外) 可以识别. 
html/**/ >body  selector { property:value; } 在选择器上运用继承法 html/**/ >body  selector ,这个Hack只有IE系列 (除IE7外) 可以识别. 
selector { property/**/:value; } 在属性名和冒号":"之间加入注释,屏蔽IE6用. 
selector/**/ { property/**/:value; } 在选择器和花括号"{"之间以及在属性名和冒号":"之间加入注释,屏蔽IE5和IE6用 (不屏蔽IE5.5) . 
select/**/ { property:value; } 在选择器和花括号"{"之间加入注释,屏蔽IE5用. 
*+html  selector { property:value !important; } 在选择器上运用继承法 *+html selector 再加上 !important, 这个Hack只有IE7可以识别. 


Firefox:


*:lang(lang) selector { property:value !important; } 用伪类lang(语言)再加上!important进行定义的话,目前只有Firefox可以识别. 


Safari:


selector:empty { property:value !important; } 用伪类empty再加上!important进行定义的话,目前只有Safari可以识别.


Opera:


@media all and (min-width: 0px){ selector { property:value; } } 利用特殊继承法进行定义的话,目前只有Opera可以识别. 


以上的Hack并不完整,大家一起补充.

对Hack的运用,最普遍的是CSS盒模型Hack,清除浮动Hack.

CSS盒模型在IE5.X上是有严重解析错误的.这个Hack针对IE5.X:


selctor { width:IE5.X宽度; voice-family :"\"}\""; voice-family:inherit; width:正确宽度; }


清除浮动Hack,相信这个定义用的人很多:


selector:after { content:"."; display:block; height:0; clear:both; visibility:hidden; }


另外还有很多很多CSS Hack的运用,一一列举的话可能能写成一本书了...想到再添加吧.

标签:CSS,Hack,浏览器,css
0
投稿

猜你喜欢

  • 查看Oracle的执行计划一句话命令

    2010-07-16 13:02:00
  • Sql Server基本函数

    2008-08-20 18:28:00
  • 提升网站可用性的3个忠告

    2008-01-31 13:48:00
  • mysql中从字段中URL提取域名信息

    2009-05-25 10:35:00
  • CSS雪碧:要还是不要?

    2009-11-16 13:01:00
  • 面向对象的XHTML与CSS编程

    2008-01-11 13:37:00
  • mysql proxy问题

    2009-02-27 15:54:00
  • SQL Server 2008 到底需要使用哪些端口?

    2012-11-30 20:29:41
  • 对Server.UrlEncode进行字符反编译

    2009-06-22 12:54:00
  • 如何跨浏览器使用连续字符的换行

    2008-07-06 23:10:00
  • ASP常见数学函数 Abs Atn Cos 等详解

    2008-05-28 12:33:00
  • 利用XMLHTTP批量生成静态页的函数

    2008-09-10 11:07:00
  • 用ASP显示ACCESS数据库的GIF图象

    2008-11-16 18:09:00
  • 如何实现固定长度的自动编号?

    2010-06-03 10:08:00
  • Tab(选项卡)的产品设计原则及应用[译]

    2009-07-09 19:05:00
  • 设计和布局之间的思考

    2008-10-09 13:06:00
  • 在IE中使用高级CSS3选择器

    2010-01-22 15:20:00
  • 学习ASP.NET八天入门:第六天

    2007-08-07 13:48:00
  • 纯CSS实现导航下拉菜单

    2007-11-25 15:11:00
  • 如何利用Image Data Type在主页中显示图形?

    2010-01-01 15:13:00
  • asp之家 网络编程 m.aspxhome.com