日期:2014-05-17  浏览次数:20848 次

常用的CSS兼容技巧

不同的浏览器,比如Internet Explorer 6,Internet Explorer 7,Mozilla Firefox等,对CSS的解析认识不一样,因此会导致生成的页面效果不一样,得不到我们所需要的页面效果。这里我们就需要注意CSS书写技巧了。

这个时候我们就需要针对不同的浏览器去写不同的CSS,让它能够同时兼容不同的浏览器,能在不同的浏览器中也能得到我们想要的页面效果。这个针对不同的浏览器写不同的CSS code的过程,就叫CSS hack,也叫写CSS hack。

由于不同的浏览器对CSS的支持及解析结果不一样,还由于CSS中的优先级的关系。我们就可以根据这个来针对不同的浏览器来写不同的CSS。

比如 IE6能识别下划线"_"和星号" * ",IE7能识别星号" * ",但不能识别下划线"_",而firefox两个都不能认识。等等

书写顺序,一般是将识别能力强的浏览器的CSS写在后面。下面列举常用的CSS hack方法

CSS书写技巧-1:!important

!important作用是提高指定样式规则的应用优先权。

IE7以及所有标准浏览器能识别!important

区别IE6与IE7与其他浏览器

  1. .browserTest
  2. {
  3. border:20px solid #60A179!important;
  4. border:20px solid #00F;
  5. }

在Mozilla中或者IE7浏览时候,能够理解!important的优先级,因此显示#60A179的颜色:

在IE6中浏览时候,不能够理解!important的优先级,因此显示#00F的颜色:

CSS书写技巧-2:*

IE都能识别*;标准浏览器(如火狐)不能识别*

区别IE6与火狐

  1. .browserTest
  2. {
  3. border:20px solid #60A179;
  4. *border:20px solid #00F;
  5. }

区别IE7与火狐

  1. .browserTest
  2. {
  3. border:20px solid #60A179;
  4. *border:20px solid #00F;
  5. }

区别IE7,IE6与火狐

  1. .browserTest
  2. {
  3. border:20px solid #60A179;
  4. *border:20px solid #00F!important;
  5. *border:20px solid ###;
  6. }

CSS书写技巧-3:_

IE6支持下划线,IE7和firefox均不支持下划线

区别IE7,IE6与火狐

  1. .browserTest
  2. {
  3. border:20px solid #60A179;
  4. *border:20px solid #00F;
  5. _border:20px solid ###;
  6. }
  7. /*不管是什么方法,书写的顺序都是firefox的写在前面,IE7的写在中间,IE6的写在最后面*/

CSS书写技巧-4:*+html 与 *html

*+html 与 *ht