转 CSS兼容性(IE和Firefox)技巧大全 (五)

 CSS兼容性(IE和Firefox)技巧大全 (五)

IE6,IE7,FF

IE7.0出来了,对CSS的支持又有新问题。浏览器多了, /*For IE7 & IE6*/ _height:20px; /*For IE6*/

这里我自己也没看懂什么意思?

 

注意顺序。


这样也属于CSS HACK,不过没有上面这样简洁。


第一种

  1. #example { color: #333; } /* Moz */
  2. * html #example { color: #666; } /* IE6 */
  3. *+html #example { color: #999; } /* IE7 */


第二种,是使用IE专用的条件注释

  1. <!--其他浏览器 -->
  2. <link rel="stylesheet" type="text/css" href="css.css" />

 

  1. <!--[if IE 7]>
  2. <!-- 适合于IE7 -->
  3. <link rel="stylesheet" type="text/css" href="ie7.css" />
  4. <![endif]-->
 
 
    <!--[if lte IE 6]>
  1. <!-- 适合于IE6及一下 -->
  2. <link rel="stylesheet" type="text/css" href="ie.css" />
  3. <![endif]-->

 

第三种,css filter的办法,以下为经典从国外网站翻译过来的。

新建一个css样式如下:

  1. #item {
  2. width: 200px;
  3. height: 200px;
  4. background: red;
  5. }:


新建一个div,并使用前面定义的css的样式:

  1. <div id="item">some text here</div>


在body表现这里加入lang属性,中文为zh:

 

  1. <body lang="en">


现在对div元素再定义一个样式:

  1. *:lang(en) #item{
  2. background:green !important;
  3. }

 

这样做是为了用!important覆盖原来的css样式,由于:lang选择器ie7.0并不支持,所以对这句话不会有任何作用,于是也达到了 ie6.0下同样的效果,但是很不幸地的是,safari同样不支持此属性,所以需要加入以下css样式:

  1. #item:empty {
  2. background: green !important
  3. }

 

:empty选择器为css3的规范,尽管safari并不支持此规范,但是还是会选择此元素,不管是否此元素存在,现在绿色会现在在除ie各版本以外的浏览器上。

对IE6和FF的兼容可以考虑以前的!important 个人比较喜欢用第一种,简洁,兼容性比较好

你可能感兴趣的:(firefox)