本文就主要以:IE6+IE7+IE8+IE9+FF为主要研究对象HACK原理:不同浏览器对各中字符的识别不同 (读完文章你会发现,FF和IE8对以下字符的识别能力完全相同)
在 CSS中常用特殊字符识别表:
(1)*: IE6+IE7都能识别*,而标准浏览器FF+IE8是不能识别*的;
(2)!important: 除IE6不能识别 !important外, FF+IE8+IE7都能识别!important ;
(3)_ : 除IE6支持_ 外, FF+IE8+IE7都不支持_;
(4)\9:所有IE浏览器都识别(IE6、IE7、IE8、IE9)
示例:
(1)区别FF(IE8)与IE6 IE7
backgorund:orange; FF 和IE8背景色将为橘黄色
*backgorund:red; IE6和IE7背景色将为红色
(2)区别 FF(IE8)与IE6与IE7
background:orange; FF和IE8背景色将为橘黄色
*background:red !important; IE7背景色将为红色
*background:blue; IE6背景色将为蓝色
(3) 区别FF(IE8)与IE6与IE7
background:orange; FF和IE8背景色将为橘黄色
*background:red; IE7 背景色将为红色
_background:blue; IE6背景色将为蓝色
(4)区别FF与IE6 IE7 E8
color:gray; FF 等非IE浏览器字体色将为灰色
color:red\9; IE8 IE9字体色将为红色
*color:green; IE7 字体色将为绿色
_color:blue; IE6 字体色将为蓝色
.lanyu{
padding:10px;
padding:9px\9; /* all ie */
padding:8px\0; /* ie8-9 */
*padding:5px; /* ie6-7 */
+padding:7px; /* ie7 */
_padding:6px; /* ie6 */
}
提示:
CSS HACK书写顺序:先写FF等非IE浏览器所需样式,其次写IE8所需样式,接着是IE7的,再接着才是IE6的!
总结:
实际运用中我感觉比较少用到!important ,只要你记住”*”和”_”我想就足够区别于FF(IE8)与IE6与IE7了.
.sofish{ padding:10px;
padding:9px\9; /* all ie */
padding:8px\0; /* ie8-9 目前应用于IE8的单独 hack,情况比较少 */
*padding:5px; /* ie6-7 */
+padding:7px; /* ie7 */
_padding:6px; /* ie6 */ }
/* webkit and opera */ @media all and (min-width: 0px){ .sofish{padding:11px;} }
/* webkit */ @media screen and (-webkit-min-device-pixel-ratio:0){ .sofish{padding:11px;} }
/* opera */ @media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) { .sofish{padding:11px;} }
/* firefox * / @-moz-document url-prefix(){ .sofish{padding:11px;}} /* all firefox */ html>/**/body .sofish, x:-moz-any-link, x:default { padding:11px; } /* newest firefox */
HTML: 添加body class
<!–[if IE6]–><body class=”ie6″><![endif]–>
<!–[if IE7]–><body class=”ie7″><![endif]–>
<!–[if IE8]–><body class=”ie8″><![endif]–>
<!–[if IE9]–><body class=”ie9″><![endif]–>
<!–[if !IE]–><body class=”non-ie”><![endif]–>
==================================================
演示代码如下:
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″ />
<title>DIV+CSS各浏览器css hack测试,www.divcss5.com测试</title>
<style type=”text/css”>
<!–
.STYLE1 { font-size:18px;color:#FF0000;*color:#00FF00 !important;color:#0000FF \9;*color:#FFFF00;}
.STYLE2,.STYLE3,.STYLE4,.STYLE5{ font-size:14px;}
.STYLE2 {color: #FFFF00}
.STYLE3 {color: #FF0000}
.STYLE4 {color: #00FF00}
.STYLE5 {color: #0000FF}
–>
</style>
</head>
<body>
<span>我是测试颜色,不在不同浏览器下显示颜色不同哦!-<a href=”http://www.divcss5.com/”>DIV+CSS</a></span><br /> www.divcss5.com版权所有
<span>我是颜色在IE6显示</span> <br />
<span>我是颜色在ie7显示</span> <br />
<span>我是颜色在ie8显示</span> <br />
<span>我是颜色在火狐(firefox)显示</span>
</body>
</html>
参考资料:
http://hi.baidu.com/marsjin/blog/item/fd4c10d19b0e64c6562c84c2.html
http://www.divcss5.com/css-hack/c27.html