日期:2014-01-20 浏览次数:21072 次
一 css的优先级
今天有人跟我说css hack中用!important来区分ie6,由于ie6不支持!important,是的在很早以前我也是用过这种方法写hack,但是后来就基本不用了。本来我对他谁的ie6不支持!important也没什么异议,可是正好在前几天正好用个这个!important属性处理了一个款式优先级的问题,而且是支持ie6的,这是为什么呢?到底ie6支不支持!important呢?
首先我们来看看!important这个属性的作用:!important是用来提升款式优先级的,我们知道款式是有优先级的。
我们先看看css的优先级的几个基本的规则:
我们可以利用!important使该款式优先级最高,例如:
CSS代码:
#idA{font-size:20px}
.classA{ font-size: 12px; }
HTML代码:
<div id=“idA” class=“classA”>我要20像素的字</div>
我们知道依据上面的规则可以看出#idA{font-size:20px}的款式将被援用,那我们如果要12像素的字呢?
CSS代码:
#idA{font-size:20px}
.classA{ font-size: 12px !important; }
HTML代码:
<div id=“idA” class=“classA”>我要12像素的字</div>
这样.classA{ font-size: 12px !important; }这个款式就被援用了。
这种方法在优先级低的款式被优先级高的款式覆盖,又想援用优先级低的款式时候非常有用!
二 !important在ie6下的一个BUG
还是看这一段代码,
CSS代码:
#idA{font-size:20px}
.classA{ font-size: 12px !important; }
HTML代码:
<div id=“idA” class=“classA”>我要12像素的字</div>
大家可以在IE6下测试一下,文字是12像素的,也就是.classA{ font-size: 12px !important; }被援用了,这证明IE6是支持!important的。但是css hack中用!important来区分ie6,说ie6不支持!important又是怎样回事呢?
原来ie6下,在同一个选择器款式(即同一个大括号里面)下!important是无效的,例如:
css代码:
.classA{ font-size: 68px !important; font-size: 12px }
HTML代码:
<div class=“classA”>我要12像素的字</div>
这里在ie6下是12像素的字,而其他浏览器下是68px的字,当然我们把款式改一下,!important放在后面,即.classA{ font-size: 12px;font-size: 68px !important; },那么ie6下和其他浏览器一样也是68px的字。也就是在同一个选择器款式(即同一个大括号里面)下!important被ie6彻底的无视了。
==============以下2009年8月1日更新==============
昨天在紫鼠的博客上也看到了关于!important的文章,说IE8在同一个选择器款式(即同一个大括号里面)下对!important的解析也是和IE6一样的,可是我测试的情况是IE8和IE6是不一样的,并留了言,今天我们讨论了这个问题,确实他写的他写的代码IE8和IE6对!important的解析是一样的。经过比较发现,他代码上没有DTD的声明,就是html代码上面的这一句:“<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>”,神啊,在没有DTD的声明的情况下,在同一个选择器款式(即同一个大括号里面)下,IE6,IE7,IE8对!important的解析都是无效的。还有只需有声明文档类型的不管是html4,xhtml1.o,还有html5(“<!DOCTYPE html>”),除去ie6有上面说的BUG外其他都是正常的。