好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

css样式---CSShack

前端样式,虽然不是经常需要hack,但是我们经常会遇到各浏览器表现不一致的情况。基于此,某些情况我们会极不情愿的使用这个不太友好的方式来达到大家要求的页面表现。我个人是不太推荐使用hack的,要知道一名好的前端,要尽可能不使用hack的情况下实现需求,做到较好的用户体验。可是啊,现实太残酷,浏览器厂商之间历史遗留的问题让我们在目标需求下不得不向hack妥协,虽然这只是个别情况。今天,结合自己的经验和理解,做了几个demo把IE6~IE10和其他标准浏览器的CSS hack做一个总结,也许本文应该是目前最全面的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浏览器不同版本之间的表现差异而引入的。

属性前缀法(即类内部Hack):例如 IE6能识别 下划线"_"和星号" * " , IE7能识别星号" * ",但不能识别下划线"_" , IE6~IE10都认识"\9" ,但firefox前述三个都不能认识。 选择器前缀法(即选择器Hack):例如 IE6能识别*html .class{} , IE7能识别*+html .class{}或者*:first-child+html .class{} 。 IE条件注释法(即HTML条件注释Hack): 针对所有IE(注:IE10+已经不再支持条件注释): IE浏览器显示的内容 ,针对IE6及以下版本: 只在IE6-显示的内容 -> 。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。

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

CSS hack方式一:条件注释法:

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

 	只在IE下生效
	 
	这段文字只在IE浏览器显示
	 
	
	只在IE6下生效
	 
	这段文字只在IE6浏览器显示
	 
	
	只在IE6以上版本生效
	 
	这段文字只在IE6以上(包括)版本IE浏览器显示
	 
	
	只在IE8上不生效
	 
	这段文字在非IE8浏览器显示
	 
	
	非IE浏览器生效
	 
	这段文字只在非IE浏览器显示
	 

CSS hack方式二:类内属性前缀法:

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

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

说明:在标准模式中

[-″减号是IE6专有的hack [\9″ IE6/IE7/IE8/IE9/IE10都生效 [\0″ IE8/IE9/IE10都生效,是IE8/9/10的hack [\9\0″ 只对IE9/IE10生效,是IE9/10的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的 标签加上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样式---CSShack的详细内容...

  阅读:38次