CSS优先级和!important与IE6的BUG讨论及解决方案
建站知识 2021-07-03 08:43www.168986.cn长沙网站建设
一、css的优先级
今天有人跟我说csshack中用!important来区分ie6,因为ie6不支持!important,是的在很早以前我也是用过这种方法写hack,后来就基本不用了。本来我对他谁的ie6不支持!important也没什么异议,可是正好在前几天正好用个这个!important属性解决了一个样式优先级的问题,而且是支持ie6的,这是为什么呢?到底ie6支不支持!important呢?
我们来看看!important这个属性的作用!important是用来提升样式优先级的,我们知道样式是有优先级的。
我们先看看css的优先级的几个基本的规则
ID选择器(形如#id{})>类选择器(形如.class{})>标签选择器(形如body{}或者{}),也就是ID选择器,类选择器,标签选择器中,ID选择器的优先级最高,标签选择器最低;选择器越具体优先级就越高,也就是
.classA.classB.classC{font-size:25px;}
.classB.classC{font-size:18px}
.classC{font-size:12px;}
这里.classA.classB.classC的优先级最高,.classC的优先级最低;
•在同一个级别的情况下,指定的规则优先级就越高,也就是我们通常说的就近原则;
•html中标签的style的属性都高于css文件中的选择器样式;
•标有”!important”的规则有最高优先级。
我们可以利用!important使该样式优先级最高,例如
#idA{font-size:20px}
.classA{font-size:12px;}
HTML代码我要20像素的字
#idA{font-size:20px}
.classA{font-size:12px!important;}
HTML代码我要12像素的字
这样.classA{font-size:12px!important;}这个样式就被引用了。
这种方法在优先级低的样式被优先级高的样式覆盖,又想引用优先级低的样式时候非常有用!
二、!important在ie6下的一个BUG
还是看这一段代码,
#idA{font-size:20px}
.classA{font-size:12px!important;}
HTML代码我要12像素的字
大家可以在IE6下测试一下,文字是12像素的,也就是.classA{font-size:12px!important;}被引用了,这证明IE6是支持!important的。csshack中用!important来区分ie6,说ie6不支持!important又是怎么回事呢?
原来ie6下,在同一个选择器样式(即同一个大括号里面)下!important是无效的,例如
.classA{font-size:68px!important;font-size:12px}
HTML代码我要12像素的字
这里在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代码上面的这一句“”,神啊,在没有DTD的声明的情况下,在同一个选择器样式(即同一个大括号里面)下,IE6,IE7,IE8对!important的解析都是无效的。还有只要有声明文档类型的不管是html4,xhtml1.o,还有html5(“”),除去ie6有上面说的BUG外其他都是正常的。
今天有人跟我说csshack中用!important来区分ie6,因为ie6不支持!important,是的在很早以前我也是用过这种方法写hack,后来就基本不用了。本来我对他谁的ie6不支持!important也没什么异议,可是正好在前几天正好用个这个!important属性解决了一个样式优先级的问题,而且是支持ie6的,这是为什么呢?到底ie6支不支持!important呢?
我们来看看!important这个属性的作用!important是用来提升样式优先级的,我们知道样式是有优先级的。
我们先看看css的优先级的几个基本的规则
ID选择器(形如#id{})>类选择器(形如.class{})>标签选择器(形如body{}或者{}),也就是ID选择器,类选择器,标签选择器中,ID选择器的优先级最高,标签选择器最低;选择器越具体优先级就越高,也就是
复制代码
代码如下:.classA.classB.classC{font-size:25px;}
.classB.classC{font-size:18px}
.classC{font-size:12px;}
这里.classA.classB.classC的优先级最高,.classC的优先级最低;
•在同一个级别的情况下,指定的规则优先级就越高,也就是我们通常说的就近原则;
•html中标签的style的属性都高于css文件中的选择器样式;
•标有”!important”的规则有最高优先级。
我们可以利用!important使该样式优先级最高,例如
复制代码
代码如下:#idA{font-size:20px}
.classA{font-size:12px;}
HTML代码我要20像素的字
复制代码
代码如下:#idA{font-size:20px}
.classA{font-size:12px!important;}
HTML代码我要12像素的字
这样.classA{font-size:12px!important;}这个样式就被引用了。
这种方法在优先级低的样式被优先级高的样式覆盖,又想引用优先级低的样式时候非常有用!
二、!important在ie6下的一个BUG
还是看这一段代码,
复制代码
代码如下:#idA{font-size:20px}
.classA{font-size:12px!important;}
HTML代码我要12像素的字
大家可以在IE6下测试一下,文字是12像素的,也就是.classA{font-size:12px!important;}被引用了,这证明IE6是支持!important的。csshack中用!important来区分ie6,说ie6不支持!important又是怎么回事呢?
原来ie6下,在同一个选择器样式(即同一个大括号里面)下!important是无效的,例如
复制代码
代码如下:.classA{font-size:68px!important;font-size:12px}
HTML代码我要12像素的字
这里在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代码上面的这一句“”,神啊,在没有DTD的声明的情况下,在同一个选择器样式(即同一个大括号里面)下,IE6,IE7,IE8对!important的解析都是无效的。还有只要有声明文档类型的不管是html4,xhtml1.o,还有html5(“”),除去ie6有上面说的BUG外其他都是正常的。
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键