各浏览器 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
投稿
猜你喜欢
仿QQ和MSN消息提示的效果代码
2010-03-16 12:17:00
JetBrains PyCharm(Community版本)的下载、安装和初步使用图文教程详解
2023-07-13 11:20:21
js断点调试心得分享(必看篇)
2023-07-06 22:13:25
如何在 IE 中使用 HTML5 元素
2009-06-14 19:44:00
ubuntu 16.04下python版本切换的方法
2021-07-10 16:36:04
python-字典dict和集合set
2021-09-30 10:10:17
Python全栈之学习HTML
2023-12-05 14:56:55
基本的页面设计元素布局比例
2007-12-15 09:43:00
记一次MySQL更新语句update的踩坑
2024-01-16 19:35:29
Flask框架单例模式实现方法详解
2023-01-24 17:04:55
MySQL 8.0.18使用clone plugin重建MGR的实现
2024-01-24 11:21:30
Go语言题解LeetCode463岛屿的周长示例详解
2024-04-25 15:09:59
numpy array找出符合条件的数并赋值的示例代码
2021-07-03 05:01:38
使用python-cv2实现Harr+Adaboost人脸识别的示例
2022-03-16 01:05:10
Vue 实现拨打电话操作
2024-05-09 15:09:53
win10 mysql导出csv的两种方式
2024-01-22 08:27:11
Python抓取手机号归属地信息示例代码
2023-03-02 21:24:59
Oracle 数据库中创建合理的数据库索引
2009-07-02 12:31:00
JSONLINT:python的json数据验证库实例解析
2022-08-13 21:53:01
python爬虫爬取网页数据并解析数据
2022-03-03 06:25:02