HTML+CSS3(八)——CSS权重

目录:

HTML+CSS3(一)——认识浏览器

HTML+CSS3(二)——HTML 初识

HTML+CSS3(三)——HTML基本标签

HTML+CSS3(四)——表单pattern正则属性

HTML+CSS3(五)——CSS基础

HTML+CSS3(六)——行内元素和块级元素

HTML+CSS3(七)——display属性(前面文章已讲过,这里转载一篇)

HTML+CSS3(八)——CSS权重

HTML+CSS3(九)——CSS高级技巧

HTML+CSS3(十)——CSS3新特性之过渡

HTML+CSS3(十)——CSS3新特性之2D变形和3D变形

HTML+CSS3(十)——CSS3新特性之动画

HTML+CSS3(十 一)——案例

HTML+CSS3(十二)——CSS常见问题


在给元素添加CSS规则(样式)时,发现并没有起到预期效果,主要原因是在某处定义了一个更高权重的规则,导致该处的规则并没有生效。因此,我们需要对CSS权重问题有一定了解。

CSS权重顺序

CSS样式优先级(就近原则):
内联样式(标签内部)>嵌入样式(<head>中的style里)>外部样式(CSS文件中)

CSS各级别的优先级:
!important > 内联 > ID > 类 > 标签 | 伪类 | 属性选择 > 伪对象 > 通配符 > 继承

!important

CSS2规范中规定:!important 用于单独指定某条样式中的单个属性。对于被指定的属性,有 !important 指定的权重值大于所有未用 !important 指定的规则。
例如:


 
 
  1. div{ background:blue !important}
  2. div .box{ background:pink}

结果效果显示背景颜色为blue
注意:当多条规则中都对同一个属性指定了 !important,!important 的作用相互抵销。

内联

写在标签内部:<标签 style=” ”></标签>


 
 
  1. <body>
  2. <div style=”width:200px;height:200px”> </div>
  3. </body>

ID


 
 
  1. <body>
  2. <div id=”box”> </div>
  3. </body>


 
 
  1. <body>
  2. <div class=”box”> </div>
  3. </body>

标签

div{width:200px}
 
 

伪类

伪类表示的是一种“状态”,如hover,active等等
常见的伪类选择器:(E代表元素)

E:link E:visited E:hover E:active            
E:focus E:not(s) E:first-child E:last-child    
E:only-child E:nth-child(n) E:nth-last-child(n) E:first-of-type 
E:last-of-type E:only-of-type E:nth-of-type(n) E:nth-last-of-type(n)
E:empty E:checked E:enabled E:disabled

属性选择

E[attr]:选择具有att属性的E元素。
E[att="val"]:选择具有att属性且属性值等于val的E元素。
例子:


 
 
  1. <head>
  2. <style>
  3. input [type] { /*拥有type属性的input元素*/
  4. color:red;
  5. }
  6. input [type="text"] { /*type属性值为text的input元素*/
  7. border: 2px solid #000;
  8. }
  9. </style>
  10. </head>
  11. <body>
  12. <input />
  13. <input type="text" />
  14. <input type="submit" />
  15. </body>

伪对象(伪元素)

伪元素表示文档的某个确定部分的表现,比如::first-line 伪元素只作用于你前面元素选择器确定的一个元素的第一行。
伪元素选择器只包含以下:
E:first-letter/E::first-letter
E:first-line/E::first-line
E:before/E::before
E:after/E::after
E::placeholder
E::selection
CSS3将伪对象选择符(Pseudo-Element Selectors)前面的单个冒号(:)修改为双冒号(::)用以区别伪类选择符(Pseudo-Classes Selectors),但以前的写法(单冒号:)仍然有效。

通配符

*{}  /*选定所有对象。*/
 
 

继承

当一个元素的某个属性没有被直接指定时,才会继承父级元素的值。

 

选择器权重值的计算

A:如果规则是写在标签的style属性中(内联样式),则A=1,否则,A=0. 对于内联样式,由于没有选择器,所以B、C、D的值都为0,即A=1, B=0, C=0, D=0(简写为1,0,0,0,下同)。

B:计算该选择器中ID的数量。如果有则B=1,没有B=0(例如,#header 这样的选择器,计算为0, 1, 0, 0)。

C:计算该选择器中伪类及其它属性的数量(包括class、属性选择器等,不包括伪元素)。(例如, .logo[id='site-logo'] 这样的选择器,计算为0, 0, 2, 0)(后面将进一解释为什么会是0,0,2,0)。

D:计算该选择器中伪元素及标签的数量。(例如,p:first-letter 这样的选择器,计算为0, 0, 0, 2)。

 

从上选择器权重值的计算可以归结为:

1. 一条样式规则的整体权重值包含四个独立的部分:[A, B, C, D];
2. A 表示内联样式,只有 1 或者 0 两个值;
3. B 表示规则中 ID 的数量;
4. C 表示规则中除了 ID、标签和伪元素以外的其它选择器数量;
5. D 表示规则中标签和伪元素的数量;

CSS2规范中给出的一些例子:


 
 
  1. 1. * {} /* a=0 b=0 c=0 d=0 -> specificity = 0,0,0,0 */
  2. 2. li {} /* a=0 b=0 c=0 d=1 -> specificity = 0,0,0,1 */
  3. 3. li:first-line {} /* a=0 b=0 c=0 d=2 -> specificity = 0,0,0,2 */
  4. 4. ul li {} /* a=0 b=0 c=0 d=2 -> specificity = 0,0,0,2 */
  5. 5. ul ol+li {} /* a=0 b=0 c=0 d=3 -> specificity = 0,0,0,3 */
  6. 6. h1 + *[rel=up]{} /* a=0 b=0 c=1 d=1 -> specificity = 0,0,1,1 */
  7. 7. ul ol li.red {} /* a=0 b=0 c=1 d=3 -> specificity = 0,0,1,3 */
  8. 8. li.red.level {} /* a=0 b=0 c=2 d=1 -> specificity = 0,0,2,1 */
  9. 9. #x34y {} /* a=0 b=1 c=0 d=0 -> specificity = 0,1,0,0 */
  10. 10. style="" /* a=1 b=0 c=0 d=0 -> specificity = 1,0,0,0 */

根据这样的定义,所以很多文章简单地把规则归纳为:内联样式的权重值是1000,ID选择器的权重值是100,class选择器的权重值是10,标签选择器的权重值是1. 整条规则中的所有选择器权重值相加得到整个样式规则的权重值,数字越大权重值越高。

大多数情况下,按照这样的理解得出的结论没有问题,但是遇到下面这样的情况就出现问题了:


 
 
  1. /* 样式一 */
  2. body header div nav ul li div p a span em { color: red}
  3. /* 样式二 */
  4. .count { color: blue}

按照错误的计算方法,样式一的权重值是11,样式二的权重值是10,如果这两条规则用于同一个元素,则该元素应该是红色。实际结果却是蓝色。

原因如下:

根据规范,计算权重值时,A, B, C, D 四组值,从左到右,分组比较,如果 A 相同,比较 B, 如果 B 相同,比较 C, 如果 C 相同,比较 D, 如果 D 相同,也就是权重相同时,后定义的优先。

样式二和样式一的 A、B 相同,而样式二的 C 大于样式一,所以,不管 D 的值如何,样式二权重值都大于样式一,因此实际结果显示为蓝色。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值