很多小伙伴在学完 CSS 之后对于选择器的选择还是比较随意,导致有时候可能出现 CSS 冲突。其实出现 CSS 冲突的根本原因,是开发者对 CSS 选择器的权重理解不到位所致。接下来的这篇文章,小编就来介绍如何进行 CSS 权重计算。

权重介绍

首先,什么是 CSS 权重呢?CSS 的权重,是选择器的相对重要程度值,也可以叫权值。这个权值决定了选择规则的优先级。通常我们对 CSS 的优先级的规则主要有下面三条:

1.CSS 权值不同时,权值高的优先;

2.CSS 权值相同时,后定义的规则优先;

3. CSS 属性后面加 ​ !important​  时,无条件绝对优先;

只要得知权值的大小,就可以根据上面的规则进行比较。

权重计算

权重的计算方式得先得到基础的选择器的权重才能进行计算,基础选择器的权重如下:

第一等级选择器:行间样式(内联样式)

第二等级选择器:id 选择器

第三等级选择器:class 选择器,伪类选择器,属性选择器

第四等级选择器:标签选择器,伪元素选择器

通用选择器(*),子选择器(>),相邻同胞选择器(+)等选择器:权重为0。

(权重为零表示对计算结果不影响,所以可以不纳入计算)

权值的计算公式为:(第一等级选择器*个数,第二选择器*个数,第三选择器*个数,第四选择器*个数)

权重比较

根据权值计算公式,得出一个四元组,通过逐一比较四元组的大小,得出权重的大小。

比如有一权重计算结果为(1,0,2,4),另一权重计算结果为(1,0,2,3),则应用第一种权重所属的选择器。

案例

<ul id="nav" class="nav">
    <li class="active" id="first"><a href=""></a></li>
</ul>

如上所示HTML代码,选中a的方式有如下几种:

ul#nav li.active a​ 权值为(0,1,1,3);

ul li.active a​ 权值为(0,0,1,2);

ul.nav li.active a​ 的权值为(0,0,2,2);

ul#nav li#first a​ 的权值为(0,2,0,2);

如果样式在行间(也就是行间样式),权值为(1,0,0,0) ;

如果某项 CSS 属性后面带 ​!important​ 时,权值最大。

总结

1.     进行权重比较的时候,按顺序从左往右进行比较;

2.     权值相同的情况下,后者优先进行渲染(也就是样式覆盖);

3.     CSS 属性后面加 ​!important​ 时,无条件绝对优先(比内联样式还要优先);

小结

以上就是 CSS 权重计算的方法。该方法虽然在工作中比较少遇到,但一旦遇到了 CSS 冲突,该方法就有了用武之地。而且如果作为求职者的话,前端面试的 HR 有时候会问到权重计算的问题,所以各位想要往前端方向发展的小伙伴们还是要掌握这项技能。

更多前端高阶知识点,可以前往 W3Cschool 的前端微课进行学习。