css3技术

CSS hack技巧

字号+ 作者:H5之家 来源:H5之家 2015-09-13 18:10 我要评论( )

CSS hack技巧一览,原文来自CSDN freshlover的博客专栏《史上最全CSS Hack方式一览》什么是CSS hack由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Fire

CSS hack技巧一览,原文来自CSDN freshlover的博客专栏《史上最全CSS Hack方式一览》

什么是CSS hack

由于不同厂商的流览器或某浏览器的不同版本(如IE6-IE11,Firefox/Safari/Opera/Chrome等),对CSS的支持、 解析不一样,导致在不同浏览器的环境中呈现出不一致的页面展现效果。这时,我们为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS 样式,我们把这个针对不同的浏览器/不同版本写相应的CSS code的过程,叫做CSS hack!

CSS hack的原理

由于不同的浏览器和浏览器各版本对CSS的支持及解析结果不一样,以及CSS优先级对浏览器展现效果的影响,我们可以据此针对不同的浏览器情景来应用不同的CSS。

CSS hack分类

CSS Hack大致有3种表现形式,CSS属性前缀法、选择器前缀法以及IE条件注释法(即HTML头部引用if IE)Hack,实际项目中CSS Hack大部分是针对IE浏览器不同版本之间的表现差异而引入的。

  

CSS hack书写顺序,一般是将适用范围广、被识别能力强的CSS定义在前面。

CSS hack方式一:条件注释法

 

这种方式是IE浏览器专有的Hack方式,微软官方推荐使用的hack方式。举例如下

只在IE下生效 <!--[if IE]> 这段文字只在IE浏览器显示 <![endif]--> 只在IE6下生效 <!--[if IE 6]> 这段文字只在IE6浏览器显示 <![endif]--> 只在IE6以上版本生效 <!--[if gte IE 6]> 这段文字只在IE6以上(包括)版本IE浏览器显示 <![endif]--> 只在IE8上不生效 <!--[if ! IE 8]> 这段文字在非IE8浏览器显示 <![endif]--> 非IE浏览器生效 <!--[if !IE]> 这段文字只在非IE浏览器显示 <![endif]-->CSS hack方式二:类内属性前缀法

属性前缀法是在CSS样式属性名前加上一些只有特定浏览器才能识别的hack前缀,以达到预期的页面展现效果。

IE浏览器各版本 CSS hack 对照表

hack写法实例IE6(S)IE6(Q)IE7(S)IE7(Q)IE8(S)IE8(Q)IE9(S)IE9(Q)IE10(S)IE10(Q)

**color青色YYYYNYNYNY

++color绿色YYYYNYNYNY

--color黄色YYNNNNNNNN

__color蓝色YYNYNYNYNN

##color紫色YYYYNYNYNY

/0color:red/0红色NNNNYNYNYN

/9/0color:red/9/0粉色NNNNNNYNYN

!importantcolor:blue !important;color:green;棕色NNYNYNYNYY

说明:在标准模式中

demo如下

<script type="text/javascript"> //alert(document.compatMode);</script><style type="text/css">body:nth-of-type(1) .iehack{ color: #F00;/* 对Windows IE9/Firefox 7+/Opera 10+/所有Chrome/Safari的CSS hack ,选择器也适用几乎全部Mobile/Linux/Mac browser*/}.demo1,.demo2,.demo3,.demo4{ width:100px; height:100px;}.hack{/*demo1 *//*demo1 注意顺序,否则IE6/7下可能无法正确显示,导致结果显示为白色背景*/ background-color:red; /* All browsers */ background-color:blue !important;/* All browsers but IE6 */ *background-color:black; /* IE6, IE7 */ +background-color:yellow;/* IE6, IE7*/ background-color:gray/9; /* IE6, IE7, IE8, IE9, IE10 */ background-color:purple/0; /* IE8, IE9, IE10 */ background-color:orange/9/0;/*IE9, IE10*/ _background-color:green; /* Only works in IE6 */ *+background-color:pink; /* WARNING: Only works in IE7 ? Is it right? */}/*可以通过javascript检测IE10,然后给IE10的<html>标签加上class=”ie10″ 这个类 */.ie10 #hack{ color:red; /* Only works in IE10 */}/*demo2*/.iehack{/*该demo实例是用于区分标准模式下ie6~ie9和Firefox/Chrome的hack,注意顺序IE6显示为:绿色,IE7显示为:黑色,IE8显示为:红色,IE9显示为:蓝色,Firefox/Chrome显示为:橘色,(本例IE10效果同IE9,Opera最新版效果同IE8)*/ background-color:orange; /* all - for Firefox/Chrome */ background-color:red/0; /* ie 8/9/10/Opera - for ie8/ie10/Opera */ background-color:blue/9/0; /* ie 9/10 - for ie9/10 */ *background-color:black; /* ie 6/7 - for ie7 */ _background-color:green; /* ie 6 - for ie6 */}/*demo3实例是用于区分标准模式下ie6~ie9和Firefox/Chrome的hack,注意顺序IE6显示为:红色,IE7显示为:蓝色,IE8显示为:绿色,IE9显示为:粉色,Firefox/Chrome显示为:橘色,(本例IE10效果同IE9,Opera最新版效果也同IE9为粉色)*/.element { background-color:orange; /* all IE/FF/CH/OP*/}.element { *background-color: blue; /* IE6+7, doesn't work in IE8/9 as IE7 */}.element { _background-color: red; /* IE6 */}.element { background-color: green/0; /* IE8+9+10 */}:root .element { background-color:pink/0; } /* IE9+10 *//*demo4*//*该实例是用于区分标准模式下ie6~ie10和Opera/Firefox/Chrome的hack,本例特别要注意顺序IE6显示为:橘色,IE7显示为:粉色,IE8显示为:黄色,IE9显示为:紫色,IE10显示为:绿色,Firefox显示为:蓝色,Opera显示为:黑色,Safari/Chrome显示为:灰色,*/.hacktest{ background-color:blue; /* 都识别,此处针对firefox */ background-color:red/9; /*all ie*/ background-color:yellow/0; /*for IE8/IE9/10 最新版opera也认识*/ +background-color:pink; /*for ie6/7*/ _background-color:orange; /*for ie6*/}@media screen and (min-width:0){ .hacktest {background-color:black/0;} /*opera*/} @media screen and (min-width:0) { .hacktest { background-color:purple/9; }/* for IE9/IE10 PS:国外有些习惯常写作/0,根本没考虑Opera也认识/0的实际 */}@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) { .hacktest { background-color:green; } /* for IE10+ 此写法可以适配到高对比度和默认模式,故可覆盖所有ie10的模式 */}@media screen and (-webkit-min-device-pixel-ratio:0){ .hacktest {background-color:gray;} } /*for Chrome/Safari*//* #963棕色 :root is for IE9/IE10, 优先级高于@media, 慎用!如果二者合用,必要时在@media样式加入 !important 才能区分IE9和IE10 *//*:root .hacktest { background-color:#963/9; } */</style>

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • divcss网页设计教程-DIVCSS布局第4课-设置页面和浏览器的元素

    divcss网页设计教程-DIVCSS布局第4课-设置页面和浏览器的元素

    2015-10-02 11:35

  • DW中的可视化效果与浏览器的为什么不同?_div+css布局教程

    DW中的可视化效果与浏览器的为什么不同?_div+css布局教程

    2015-09-28 19:06

  • 如何让层垂直居中于浏览器窗口?_div+css布局教程

    如何让层垂直居中于浏览器窗口?_div+css布局教程

    2015-09-28 13:21

  • CSS布局中可以用javascript判定浏览器版本_div+css布局教程

    CSS布局中可以用javascript判定浏览器版本_div+css布局教程

    2015-09-25 15:00

网友点评
i