点评:!important只有Ie7.0和firefox可以识别,但是Ie6.0不能成功应用,在本文将为大家介绍下!important的使用方法,感兴趣的朋友可以了解下
*对于Ie系列浏览器都能够识别, firefox 浏览器则不能识别;
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网!important只有Ie7.0和firefox可以识别,但是Ie6.0不能成功应用.
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网(1)区别ie与firefox的hack为:
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网border:2px solid #f00;
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网*border:1px solid #f00;
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网(2)区别Ie6.0 与Ie7.0、firefox的hack为:
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网border:1px solid #f00!important;
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网border:2px solid #f00;
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网在(1)中,之所以把*放在后面是因为ff不识别*而导致只对它设置了一次border;而ie 系列进行了两次border设置后,后一个属性覆盖了前一个属性,故为一像素的边框。
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网在(2)中,之所以把!important放在第一个border 设置,是因为它把这次border的优先级提高了,即使后面在一次甚至在N次设置border 也无效,但是Ie6.0对这个规则不接受,而导致它应用了第二次的border 设置,也就是第二次覆盖了第一次的这一原理, 并不是它不识别!important;所以它的border为2 像素的红框.
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网CSS
EuPHTML5中文学习网 - HTML5先行者学习网 EuPHTML5中文学习网 - HTML5先行者学习网
1 #Box div{ EuPHTML5中文学习网 - HTML5先行者学习网
color:red; EuPHTML5中文学习网 - HTML5先行者学习网
} EuPHTML5中文学习网 - HTML5先行者学习网
2 .important_false{ EuPHTML5中文学习网 - HTML5先行者学习网
color:blue; EuPHTML5中文学习网 - HTML5先行者学习网
} EuPHTML5中文学习网 - HTML5先行者学习网
3.important_true{ EuPHTML5中文学习网 - HTML5先行者学习网
color:blue !important; EuPHTML5中文学习网 - HTML5先行者学习网
} EuPHTML5中文学习网 - HTML5先行者学习网
EuPHTML5中文学习网 - HTML5先行者学习网HTML
EuPHTML5中文学习网 - HTML5先行者学习网 EuPHTML5中文学习网 - HTML5先行者学习网
<div id="Box"> EuPHTML5中文学习网 - HTML5先行者学习网
<div class="important_false">这一行末使用important</div> EuPHTML5中文学习网 - HTML5先行者学习网
<div class="important_true">这一行使用了important</div> EuPHTML5中文学习网 - HTML5先行者学习网
</div> EuPHTML5中文学习网 - HTML5先行者学习网
EuPHTML5中文学习网 - HTML5先行者学习网 EuPHTML5中文学习网 - HTML5先行者学习网
第一行字为红色,第二行子为蓝色。 EuPHTML5中文学习网 - HTML5先行者学习网
important对 一个良好(或者是标准)的浏览器来说,不仅仅是从顺序上提升代码的优先级,还可以用来提升class的优先级(比如firefox),但是从IE对前者的不支持可以看出,这只是IE的一大BUG,而不能说它“不认识、不支持”! EuPHTML5中文学习网 - HTML5先行者学习网
在IE中对盒模型(box-model)的解释是有BUG的,IE6.0之前的版本会把某元素的边框值和填充值包含在宽度之内(而不是加在宽度值上)。例如,你可能会使用以下css来指定某个容器的尺寸: EuPHTML5中文学习网 - HTML5先行者学习网
EuPHTML5中文学习网 - HTML5先行者学习网 EuPHTML5中文学习网 - HTML5先行者学习网
#box EuPHTML5中文学习网 - HTML5先行者学习网
{ EuPHTML5中文学习网 - HTML5先行者学习网
width:100px; EuPHTML5中文学习网 - HTML5先行者学习网
border:5px; EuPHTML5中文学习网 - HTML5先行者学习网
padding:20px; EuPHTML5中文学习网 - HTML5先行者学习网
} EuPHTML5中文学习网 - HTML5先行者学习网
EuPHTML5中文学习网 - HTML5先行者学习网EuPHTML5中文学习网 - HTML5先行者学习网然后在html中应用:盒的总宽度在几乎所有浏览器中为150像素(100像素宽度+两条5像素的边框+两个20像素的填充),唯独在IE6之前版本的浏览器中仍然为100像素(边框值和填充值包含在宽度值中),使用盒模型的hack可以解决这一问题
EuPHTML5中文学习网 - HTML5先行者学习网 EuPHTML5中文学习网 - HTML5先行者学习网
#box EuPHTML5中文学习网 - HTML5先行者学习网
{ EuPHTML5中文学习网 - HTML5先行者学习网
width:150px; //这个是错误的width,所有浏览器都读到了 EuPHTML5中文学习网 - HTML5先行者学习网
voice-family: /}/; //IE5.X/win忽略了/}/后的内容 EuPHTML5中文学习网 - HTML5先行者学习网
voice-family:inherit; EuPHTML5中文学习网 - HTML5先行者学习网
width:100px; //包括IE6/win在内的部分浏览器读到这句,新的数值(100px)覆盖掉了旧的 EuPHTML5中文学习网 - HTML5先行者学习网
} EuPHTML5中文学习网 - HTML5先行者学习网