CSS hack大全

 

一、什么是CSS hack?css

CSS hack是经过在CSS样式中加入一些特殊的符号,让不一样的浏览器识别不一样的符号(什么样的浏览器识别什么样的符号是有标准的,CSS hack就是让你记住这个标准),以达到应用不一样的CSS样式的目的,好比.kwstu{width:300px;_width:200px;},通常浏览器会先给元素使用width:300px;的样式,紧接着后面还有个_width:200px;因为下划线_width只有IE6能够识别,因此此样式在IE6中实际设置对象的宽度为200px,后面的把前面的给覆盖了,而其余浏览器不识别_width不会执行_width:200px;这句样式,因此在其余浏览器中设置对象的宽度就是300px;java

如下是引自百度文库的定义web

简单地讲,css hack指各版本及各品牌浏览器之间对CSS解释后出现网页内容的偏差(好比咱们常说错位)的处理。因为各浏览器的内核不一样,因此会形成一些偏差就像JS同样,一个JS网页特效,在微软IE六、IE七、IE8浏览器有效果,但可能在火狐(Mozilla Firefox)谷歌浏览器无效,这样就叫作JS hack ,因此咱们对于CSS来讲他们来解决各浏览器对CSS解释不一样所采起的区别不一样浏览器制做不一样的CSS样式的设置来解决这些问题就叫做CSS Hack。

注意:咱们一般主要考虑的浏览器有IE六、IE七、IE八、谷歌浏览器(chrome)、火狐(Mozilla Firefox)便可,至于咱们经常使用的傲游、QQ的TT浏览器是用你计算机中装的系统自带浏览器的内核,因此只须要兼容以上浏览器便可兼容TT\傲游浏览器。chrome

 

二、CSS hack解决问题

CSS hack用来解决有些css属性在不一样浏览器中显示的效果不同的问题,如margin属性在ie6中显示的距离会比其余浏览器中显示的距离宽2倍,也就是说margin-left:20px;在ie6中距左侧对象的实际显示距离是40px,而在非ie6中显示的距左侧对象的距离是设置的值20px;因此要想设置一个对象距离左侧对象的距离在全部浏览器中都显示是20px的宽度的样式应为:.kwstu{margin-left:20px;_margin-left:20px;}。浏览器

 

三、浏览器识别字符标准对应表

从上图能够分析出如下几种状况:工具

1.大部分特殊字符IE浏览器支持,其余主流浏览器firefox,chrome,opera,safari不支持 (opera可识别除外)。
2.\9    :全部IE浏览器都支持
3._和-  :仅IE6支持
4.*     :IE六、E7支持
5.\0    :IE八、IE9支持,opera部分支持
6.\9\0  :IE8部分支持、IE9支持
7.\0\9  :IE八、IE9支持
 
四、各类CSS hack状况介绍
1. 区别IE和非IE浏览器
#tip{ 
background:blue;/*非IE背景蓝色  由于全部浏览器都能解释*/ 
background:red\9;/*IE六、IE七、IE八、IE9背景紅色 由于\9在IE6.7.8.9中能够识别,覆盖上面样式 IE10跟11应该不识别,IE11测试肯定*/ 
2.区别IE6,IE7,IE8,FF

【区别符号】:“\9”、“*”、“_”布局

#tip{ 
background:blue;/*Firefox背景变蓝色 全部浏览器都支持*/ 
background:red\9;/*IE8背景变红色 IE六、七、八、9支持覆盖上面样式*/ 
*background:black;/*IE7背景变黑色 IE六、7支持又一次覆盖上面样式*/ 
_background:orange;/*IE6背景变橘色 紧IE6支持又一次覆盖上面样式*/ 
}  
【说明】:由于IE系列浏览器可读「\9」,而IE6和IE7可读「*」(米字号),另外IE6可辨识「_」(底线),所以能够依照顺序写下来,就会让浏览器正确的读取到本身看得懂得CSS语法,因此就能够有效区分IE各版本和非IE浏览器(像是Firefox、Opera、GoogleChrome、Safari等)。
3.区别IE六、IE七、Firefox(方法1)

【区别符号】:“*”、“_”测试

#tip{  
background:blue;/*Firefox背景变蓝色*/  
*background:black;/*IE7背景变黑色*/  
_background:orange;/*IE6背景变橘色*/  
【说明】:IE7和IE6可读「*」(米字号),IE6又能够读「_」(底线),可是IE7却没法读取「_」,至于Firefox(非IE浏览器)则彻底没法辨识「*」和「_」,所以就能够透过这样的差别性来区分IE六、IE七、Firefox
4.区别IE六、IE七、Firefox(方法2)

【区别符号】:“*”、“!important”url

#tip{  
background:blue;/*Firefox背景变蓝色*/  
*background:green!important;/*IE7背景变绿色*/  
*background:orange;/*IE6背景变橘色*/  
【说明】:IE7能够辨识「*」和「!important」,可是IE6只能够辨识「*」,却没法辨识「!important」,至于Firefox能够读取「!important」但不能辨识「*」所以能够透过这样的差别来有效区隔IE六、IE七、Firefox。
5.区别IE七、Firefox

【区别符号】:“*”、“!important”firefox

#tip{  
background:blue;/*Firefox背景变蓝色*/  
*background:green!important;/*IE7背景变绿色*/  
【说明】:由于Firefox能够辨识「!important」但却没法辨识「*」,而IE7则能够同时看懂「*」、「!important」,所以能够两个辨识符号来区隔IE7和Firefox。
6.区别IE六、IE7(方法1)

【区别符号】:“*”、“_”

#tip{  
*background:black;/*IE7背景变黑色*/  
_background:orange;/*IE6背景变橘色*/  
【说明】:IE7和IE6均可以辨识「*」(米字号),但IE6能够辨识「_」(底线),IE7却没法辨识,透过IE7没法读取「_」的特性就能轻鬆区隔IE6和IE7之间的差别。
7.区别IE六、IE7(方法2)

【区别符号】:“!important”

#tip{  
background:black!important;/*IE7背景变黑色*/  
background:orange;/*IE6背景变橘色*/  
【说明】:由于IE7可读取「!important;」但IE6却不行,而CSS的读取步骤是从上到下,所以IE6读取时因没法辨识「!important」而直接跳到下一行读取CSS,因此背景色会呈现橘色。
8.区别IE六、Firefox

【区别符号】:“_”

#tip{  
background:black;/*Firefox背景变黑色*/  
_background:orange;/*IE6背景变橘色*/  
【说明】:由于IE6能够辨识「_」(底线),可是Firefox却不行,所以能够透过这样的差别来区隔Firefox和IE6,有效达成CSShack。
 
五、IE浏览器下hack总结
element{
color:#666\9; //IE8 IE9
* color:#999;   //IE7
_color:#EBEBEB; //IE6
}

能够看出,利用字符识别没法区分IE8和IE9,咱们能够从伪类的识别来区分

element{
color:#666\9;      //IE8
* color:#999;        //IE7
_color:#EBEBEB;      //IE6
}
:root element{color:#666\9;}//IE9
【说明】:“:root”伪类IE系列只有IE9支持,其余主流浏览器均支持,利用这一点来区分IE8和IE9。另外考虑到opera部分支持,彻底支持:root,因此不使用。
 
六、其余主流浏览器css hack总结
1.Firefox浏览器: mozilla私有属性
@-moz-document url-prefix(){ .element{color:#f1f1f1;}} //Firefox
2. Webkit和Opera:
@media all and (min-width: 0px){ .element{color:#777;} }
//Webkit
@media screen and (-webkit-min-device-pixel-ratio:0)
{
.element{color:#444;}
}
//Opera
@media all and (-webkit-min-device-pixel-ratio:10000), not all and (-webkit-min-device-pixel-ratio:0) {
.element{color:#336699;}
}
 
七、兼容各大主流浏览器(最新版本)css hack汇总以下(最全的):
.element{
color:#000;             /*w3c标准*/
[;color:#f00;];         /*Webkit(chrome和safari)*/
color:#666\9;           /*IE8*/
*color:#999;            /*IE7*/
_color:#333;            /*IE6*/
}
:root .element{color:#0f0\9;}  /*IE9*/
@media all and (-webkit-min-device-pixel-ratio:10000), not all and (
-webkit-min-device-pixel-ratio:0) { .element{color:#336699;}}  /*opera*/
@-moz-document url-prefix(){ .element{color:#f1f1f1;}} /*Firefox*/
 
八、建议:实际开发先若是不是很清楚能够先写布局代码,写一个阶段用浏览器测试工具(经常使用工具推荐IETEST)测试一个各个版本浏览器的布局效果,若有问题针对有问题的浏览器单独调试。

【转】原文地址:http://www.kwstu.com/Admin/ViewArticle/201409011604277330

相关文章
相关标签/搜索