1. 首页

这些CSS权重知识,你足够了解吗?

前言

css权重很多人都听过,也了解一些,但是很多人对具体的规则或者说再深如一些关于css权重的问题,可能会不那么清楚。日常开发中,或多或少都会遇到css规则不生效的问题,为了让我们能够减少调试css规则的时间,深刻理解css权重,就十分关键了。如果喜欢的话可以点波赞/关注,支持一下,希望大家看完本文可以有所收获。


权重规则总结:

  1. !important 优先级最高,但也会被权重高的important所覆盖
  2. 行内样式总会覆盖外部样式表的任何样式(除了!important)
  3. 单独使用一个选择器的时候,不能跨等级使css规则生效
  4. 如果两个权重不同的选择器作用在同一元素上,权重值高的css规则生效
  5. 如果两个相同权重的选择器作用在同一元素上:以后面出现的选择器为最后规则.
  6. 权重相同时,与元素距离近的选择器生效

JS中文网 – 前端进阶资源教程 www.javascriptC.com
一个致力于帮助开发者用代码改变世界为使命的平台,每天都可以在这里找到技术世界的头条内容


css权重优先级用来干嘛?

在同一个元素使用不同的方式,声明了相同的一条或多条css规则,浏览器会通过权重来判断哪一种方式的声明,与这个元素最为相关,从而在该元素上应用这个声明方式声明的所有css规则

权重的五个等级及其权重

  • !important;

  • 行内样式;

  • ID选择器, 权重:100;

  • class,属性选择器和伪类选择器,权重:10;


属性选择器指的是:根据元素的属性及属性值来选择元素,比如button的type属性等。 伪类选择器: :active :focus等选项.
  • 标签选择器和伪元素选择器,权重:1;

伪元素选择器: :before :after

等级关系:


!important>行内样式>ID选择器 > 类选择器 | 属性选择器 | 伪类选择器 > 元素选择器

权重规则:

1.不推荐使用!important

不推荐使用!important,因为!important根本没有结构与上下文可言,并且很多时候权重的问题,就是因为不知道在哪里定义了一个!important而导致的。

覆盖important:

虽然我们应该尽量避免使用!important,但你应该知道如何覆盖important,加点权重就可以实现,codepen的demo


//!important 优先级最高,但也会被权重高的important所覆盖 <button id="a" class="a">aaa</button> #a{ background: blue !important; /* id的important覆盖class的important*/ } .a{ background: red !important; }

2.行内样式总会覆盖外部样式表的任何样式,会被!important覆盖

3.单独使用一个选择器的时候,不能跨等级使css规则生效

无论多少个class组成的选择器,都没有一个ID选择器权重高。类似的,无论多少个元素组成的选择器,都没有一个class选择器权重高、无论多少个ID组成的选择器,都没有行内样式权重高。

codepen的demo;


在demo中使用了11个class组成一个选择器,最后还是一个ID选择器,设置的样式生效。

可以想象在玄幻小说的那种等级制度,没有突破那个等级,就没有可比性。

所以权重是在双方处于同一等级的情况下,才开始对比。

4.如果两个权重不同的选择器作用在同一元素上,权重值高的css规则生效

选择器可能会包含一个或者多个与权重相关的计算点,若经过权重值计算得到的权重值越大,则认为这个选择器的权重高。举一个简单的栗子:

JS中文网 – 前端进阶资源教程 www.javascriptC.com
一个致力于帮助开发者用代码改变世界为使命的平台,每天都可以在这里找到技术世界的头条内容


.test #test{ } // id 100+class 10=110; .test #test span{} // id 100+class 10+span 1=111; .test #test .sonClass{} // id 100+class 10+class 10=120; //生效

5.如果两个相同权重的选择器作用在同一元素上:以后面出现的选择器为最后规则.

demo


<div id="app"> <div class="test" id="test"> <span >啦啦啦</span> </div> </div> #test span{ color:blue; } #app span{ // 生效 因为后面出现 color: red; }

6.权重相同时,与元素距离近的选择器生效

比如不同的style表,head头部等,来看下面的栗子:


#content h1 { // css样式表中 padding: 5px; } <style type="text/css"> #content h1 { // html头部 因为html头部离元素更近一点,所以生效 padding: 10px; } </style>

建议:

  1. 避免使用!important;
  2. 利用id增加选择器权重;
  3. 减少选择器的个数(避免层层嵌套);

结语

以上就是本文关于css权重的内容了,如有不对的地方欢迎指正!希望大家看完可以有所收获,喜欢的话,赶紧点波订阅关注/喜欢。

希望看完的朋友可以点个喜欢/关注,您的支持是对我最大的鼓励。

个人blog and 掘金个人主页,如需转载,请放上原文链接并署名。码字不易,感谢支持!本人写文章本着交流记录的心态,写的不好之处,不撕逼,但是欢迎指点。

参考资料:

你应该知道的一些事情——CSS权重

深入CSS优先级

css优先级

看完两件小事

如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:

  1. 关注我们的 GitHub 博客,让我们成为长期关系
  2. 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
  3. 关注公众号 「画漫画的程序员」,公众号后台回复「资源」 免费领取我精心整理的前端进阶资源教程

JS中文网是中国领先的新一代开发者社区和专业的技术媒体,一个帮助开发者成长的社区,目前已经覆盖和服务了超过 300 万开发者,你每天都可以在这里找到技术世界的头条内容。欢迎热爱技术的你一起加入交流与学习,JS中文网的使命是帮助开发者用代码改变世界

本文来源于网络,其版权属原作者所有,如有侵权,请与小编联系,谢谢!

转载请注明:文章转载自「 Js中文网 · 前端进阶资源教程 」https://www.javascriptc.com

标题:这些CSS权重知识,你足够了解吗?

链接:https://www.javascriptc.com/2350.html

原文链接:https://juejin.im/post/5afa98bf51882542c832e5ec

« 关于CSS-BFC深入理解之布局概念
前端高频笔试题面试题记录(上)»
Flutter 中文教程资源

相关推荐

QR code