CSS中使用!important解决IE6 IE7 Firefox兼容性问题

开发 前端
本文向大家描述一下CSS兼容性解决方法!important的IE6 IE7 Firefox问题,首先让我来看一下!important问题的引起的问题。

你对CSS中使用!important解决IE6 IE7 Firefox兼容性问题的方法是否了解,这里和大家分享一下,首先我们看一下盒模型的概念。

CSS中使用!important解决IE6 IE7 Firefox兼容性问题

◆首先谈谈!important问题的引起(盒模型问题):

在CSS标准中,一个盒模型包括4个区,分别是:内容、内边距(padding)、边框(border)和外边距(margin)。而Width宽度的计算,CSS有它的标准。但是实际上,不同的浏览器的表现却不同。比如,
Firefox(FF)是准确按照CSS标准:width为内容的宽度,也就是说:
层的宽度=width+padding(leftandright)+border-width;

而IE则把width作为整个层的宽度:
内容的宽度=width-padding-border-width;

IE的这种解析,被认为是一个BUG。但事实上,这种解释也不无道理,人们在设计页面的时候关注得更多的是盒子的大小,而不是内容的大小。正是因为浏览器的不同解析,给CSS的设计带来一些困难。

◆针对这个问题,我们经常使用!important来区分Firefox和IE6.0:

以下为引用的内容: 

  1. #content  
  2. {  
  3.   width:414px!important;  
  4.   width:400px;  
  5.   padding:5px;/*只给出一个值,表示上右下左的边距都为5px*/  
  6.   border-width:2px;  
  7. }  

 Firefox识别!important,而IE不识别,且!important的width优先级高,因此FF理解为width:400px,IE6.0理解为width:414px,从而显示就相同了。

  但是问题出在IE7,IE7.0对!important有了识别能力,但是对盒模型的解析却和IE6.0等一样,从而造成很大的麻烦。也就是说,!important的方法在IE7.0下变得不适用了。
  而一般的情况下,border的使用相对较少的,并且border-width一般较小,因此最主要的问题就出在padding上了。网上很多人总结的经验是:padding要尽量少用,能用margin的,就别用padding。这种说法是消极的,问题的解决不应该总是回避。

盒模型问题的解决:

仔细想想,其实问题就出在“width与padding/border-width的同时定义”上。而明白了这一点,解决的方法就不难想到了,只要添加一个无width定义的wrapper层,把原来的一个content层拆分成2个层,在wrapper中定义padding和border-width,然后在content中定义width:

以下为引用的内容: 

  1. #wrapper{padding:5px;border-width:2px;}  
  2.  
  3. #content{margin:0px;width:400px;}  
  4.  

 以下为引用的内容: 

  1. <dividdivid="wrapper"> 
  2.   <dividdivid="content"> 
  3.     ...  
  4.   </div> 
  5. </div> 
  6.  

这样问题就可以得到解决,FF,IE6.0以及IE7.0都会获得相同的显示效果。更重要的是,没有使用任何CSShack。

这种解决方法可以说是最终的方案,使用CSShack的方法只是目前过渡阶段的临时方法。
对于网站构造,特别是对于样式比较复杂的网站,个人建议在重要的层快外加上wrapper层。但是对于目前现成的模板,可以有选择修改部分样式,或者使用其他方法。

是否适合所有的浏览器?

理论上,这种方法应该适用于各种浏览器。
但是本人认为除非大型网站,兼容FF,IE6.0,IE7.0已经足够,这里也是主要针对这三个最主流的浏览器,IE更低版本,以及其他浏览器上的可行性有待验证。
 

【编辑推荐】

  1. 主流浏览器CSS Reset的方法
  2. DIV层在IE6下被下拉框遮挡的解决方法
  3. JavaScript巧解IE6至IE8兼容问题
  4. 深入探究IE8和IE7的24个区别
  5. CSS中轻松实现Firefox与IE透明度

 

 

责任编辑:佚名 来源: phperz.com/
相关推荐

2010-08-27 15:08:10

FirefoxIE6IE7

2010-08-30 09:35:35

IE6IE7Firefox

2010-09-06 15:06:29

IE6IE7Firefox

2010-09-15 11:32:37

IE6IE7浏览器兼容性

2010-09-16 13:33:47

IE6IE7IE8

2010-08-18 15:22:28

IE6IE7Firefox

2010-08-18 13:54:35

IE6IE7Firefox兼容

2010-09-15 10:14:19

IE7IE8兼容CSS

2010-09-16 13:17:31

IE6IE7IE8

2010-08-17 15:33:28

CSS兼容IE7IE8

2010-09-15 08:41:25

IE6IE7Firefox兼容

2010-08-27 15:38:21

兼容IE6IE7

2010-08-20 09:33:22

IE6IE7IE8

2010-08-18 14:14:41

IE6IE7FF

2010-08-18 15:57:14

IE6IE7IE8

2010-08-20 13:15:54

IE6IE7IE8

2010-08-20 11:01:10

IE7IE8CSS

2010-08-18 09:24:09

IE6兼容性

2010-08-20 12:45:41

IE6IE7Firefox

2010-08-18 14:21:48

FirefoxIE7IE6
点赞
收藏

51CTO技术栈公众号