目前比较全面的浏览器CSS BUG兼容汇总

2020-05-10 11:44:24易采站长站整理

 

下面是三个浏览器的兼容性收集.

 
第一种,是CSS HACK的方法    
height:20px; /*For Firefox*/    
*height:25px; /*For IE7 & IE6*/    
_height:20px; /*For IE6*/    
注意顺序。 
  
这样也属于CSS HACK,不过没有上面这样简洁。    
#example { color: #333; } /* Moz */    
* html #example { color: #666; } /* IE6 */    
*+html #example { color: #999; } /* IE7 */  

第二种,条件注释
<!–其他浏览器 –>    
<link rel="stylesheet" type="text/css" href="css.css" />    
<!–[if IE 7]>  <!– 适合于IE7 –>    
<link rel="stylesheet" type="text/css" href="ie7.css" />    
<![endif]—>    
<!–[if lte IE 6]>    
<!– 适合于IE6及一下 –>    
<link rel="stylesheet" type="text/css" href="ie.css" />    
<![endif]—>  

第三种,css filter的办法,以下为经典从国外网站翻译过来的。
新建一个css样式如下:    
#item 
{         
width: 200px;         
height: 200px;         
background: red;    
}    

新建一个div,并使用前面定义的css的样式:    
<div id="item">some text here</div>     
在body表现这里加入lang属性,中文为zh: <body lang="en">     
现在对div元素再定义一个样式:    *:lang(en) #item{ background:green !important;}     
这样做是为了用!important覆盖原来的css样式,由于:lang选择器ie7.0并不支持,所以对这句话不会有任何作用,
于是也达到了ie6.0下同样的效果,但是很不幸地的是,safari同样不支持此属性,所以需要加入以下css样式:    
#item:empty {background: green !important    }     
:empty选择器为css3的规范,尽管safari并不支持此规范,
但是还是会选择此元素,不管是否此元素存在,现在绿色会现在在除ie各版本以外的浏览器上。    
对IE6和FF的兼容可以考虑以前的!important 个人比较喜欢用第一种,简洁,兼容性比较好。