什么是css hack?

来源:互联网 发布:大数据分析预测 知乎 编辑:程序博客网 时间:2024/05/16 14:38

什么是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浏览器不同版本之间的表现差异而引入的。属性前缀法(即类内部Hack):例如 IE6能识别下划线"_"和星号" * ",IE7能识别星号" * ",但不能识别下划线"_",IE6~IE10都认识"\9",但firefox前述三个都不能认识。选择器前缀法(即选择器Hack):例如 IE6能识别*html .class{},IE7能识别*+html .class{}或者*:first-child+html .class{}。IE条件注释法(即HTML条件注释Hack):针对所有IE(注:IE10+已经不再支持条件注释): <!--[if IE]>IE浏览器显示的内容 <![endif]-->,针对IE6及以下版本: <!--[if lt IE 6]>只在IE6-显示的内容 <![endif]-->。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。

CSS 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方式二:类内属性前缀法

实例:

<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>

css back解决兼容性的一些技巧

     1.FF下给 div 设置 padding 后会导致 width 和 height 增加, 但IE不会.(可用!important解决)         2. 居中问题.       1).垂直居中.将 line-height 设置为 当前 div 相同的高度, 再                  通过 vertical-  align: middle.( 注意内容不要换行.)      2).水平居中. margin: 0 auto;(当然不是万能)      3).若需给 a 标签内容加上样式  需要设置 display: block;(常见于导航标签)      4).FF 和 IE 对 BOX 理解的差异 导致相差 2px 的还有设为 float的div在ie下 margin加倍等问题.       5).ul 标签在 FF 下面默认有 list-style 和 padding . 最好事先声明, 以避免不必要的麻烦. (常见于导航标签和内容列表)       6).作为外部 wrapper 的 div 不要定死高度, 最好还加上 overflow: hidden.以达到高度自适应.       7). 关于手形光标. cursor: pointer. 而hand 只适用于 IE.

3. 针对firefox ie6 ie7的css样式

     现在大部分都是用!important来hack,对于ie6和firefox测试可以正常显示,

但是ie7对!important可以正确解释,会导致页面没按要求显示!找到一个针对IE7不错的hack方式就是使用“*+html”,现在用IE7浏览一下,应该没有问题了。 现在写一个CSS可以这样:

1 { color: #333; }

     * html #1 { color: #666; }      *+html #1 { color: #999; }        那么在firefox下字体颜色显示为#333,IE6下字体颜色显示为#666,IE7下字体颜色显示为#999。

4.css布局中的居中问题

   主要的样式定义如下:   body {TEXT-ALIGN: center;}

center { MARGIN-RIGHT: auto; MARGIN-LEFT: auto; }

  说明:首先在父级元素定义TEXT-ALIGN: center;这个的意思就是在父级元素内的内容居中;对于IE这样设定就已经可以了。但在mozilla中不能居中。解决办法就是在子元素定义时候设定时再加上“MARGIN-RIGHT: auto;MARGIN-LEFT: auto; ”需要说明的是,如果你想用这个方法使整个页面要居中,建议不要套在一个DIV里,你可以依次拆出多个div,只要在每个拆出的div里定义MARGIN-RIGHT: auto;MARGIN-LEFT: auto; 就可以了。

5.盒模型不同解释.

 #box{ width:600px; //for ie6.0- w\idth:500px; //for ff+ie6.0}#box{ width:600px!important //for ff width:600px; //for ff+ie6.0 width :500px; //for ie6.0-} 
0 0
原创粉丝点击