资讯专栏INFORMATION COLUMN

CSS中选择器的权重值

BlackHole1 / 1995人阅读

摘要:内联样式外部样式选择器类型选择器栗子标签属性伪类伪元素相邻选择器子代选择器权重计算规则内联样式,如,权值为。选择器,如,权值为。之所以有这样的错觉,是因为确实行间为第一等的权重,所以它的权重是最高的。通配符子选择器相邻选择器等的。

CSS 具有自己的优先级计算方法,而不仅仅是行间>内部>外部、ID>class>元素

1. 样式类型

行间样式

我的行间CSS样式。

内联样式

外部样式

2. 选择器类型
选择器 栗子
ID #id
class .class
标签 p
属性 [type="text"]
伪类 :hover
伪元素 ::first-line
相邻选择器、子代选择器 > +
3. 权重计算规则

内联样式,如: style="...",权值为1000

ID选择器,如:#content,权值为0100

类,伪类、属性选择器,如.content,权值为0010

类型选择器、伪元素选择器,如div p,权值为0001

通配符、子选择器、相邻选择器等。如* > +,权值为0000

继承的样式没有权值

4. 比较规则

1,0,0,0 > 0,99,99,99。也就是说从左往右逐个等级比较,前一等级相等才往后比。

无论是行间、内部和外部样式,都是按照这个规则来进行比较。而不是直观的行间>内部>外部样式;ID>class>元素。之所以有这样的错觉,是因为确实行间为第一等的权重,所以它的权重是最高的。而内部样式可能一般写在了外部样式引用了之后,所以覆盖掉了之前的。

在权重相同的情况下,后面的样式会覆盖掉前面的样式。

通配符、子选择器、相邻选择器等的。虽然权值为0000,但是也比继承的样式优先,0 权值比无权值优先。

5. !important

!important 的作用是提升优先级,换句话说。加了这句的样式的优先级是最高的(比内联样式的优先级还高)。


我显示红色

 

ie7+和别的浏览器对important的这种作用的支持度都很好。只有ie6-有些bug

p{
  color:red !important;
  color:blue;    
}        //会显示blue

但是这并不说明ie6不支持important,只是支持上有些bug。

p{color:red !important;  }
p{color:blue;}        // 这样就会显示的是red。说明ie6还是支持important的

!important 规则被应用在一个样式声明中时,该样式声明会覆盖CSS中任何其他的声明,无论它处在声明列表中的哪个位置。尽管如此,!important 规则还是与优先级毫无关系。使用 !important 不是一个好习惯,因为它改变了你样式表本来的级联规则,从而难以调试。
在使用 !important 时需要注意:

Never 永远不要在全站范围的 css 上使用 !important

Only 只在需要覆盖全站或外部 css(例如引用的 ExtJs 或者YUI )的特定页面中使用 !important

Never 永远不要在你的插件中使用 !important

Always 要优化考虑使用样式规则的优先级来解决问题而不是 !important

网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~

参考:

CSS 选择器权重计算规则

MDN 优先级是如何计算的?

PS:欢迎大家关注我的公众号【前端下午茶】,一起加油吧~

另外可以加入「前端下午茶交流群」微信群,长按识别下面二维码即可加我好友,备注加群,我拉你入群~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/113038.html

相关文章

  • CSS优先级的及其衡量标准CSS权重

    摘要:优先级是由权重来作为衡量标准的,权重的计算有一套计算公式,有如下规范使用一个位数的字串来表示级别,从左到右,左边的做大,往右依次递减,且数位之间没有进制,级别之间不可逾越。定义了一个命令,该命令被赋予最大的优先级。一、背景 CSS有三大特性:层叠性、继承性、优先级。 而我们在给CSS定义样式的时候,经常出现两个及以上的规则应用在同一元素上,单该元素最终在浏览器呈现的效果是应用的哪个规则呢?这...

    ky0ncheng 评论0 收藏0
  • [译]HTML&CSS Lesson3: 了解CSS

    摘要:我们会在组合选择器中来了解为什么权重值要加连字符。组合选择器中的权重值会分别对不同类型的选择器进行计数。对比两组选择器,第二组选择器有两个选择器,拥有更高的权重值。 CSS是一门复杂的语言,拥有相当的大能力。 它我们允许为页面添加布局和设计,允许多个元素甚至多个页面共享样式。在我们有能力解锁所有功能之前,我们必须先充分理解它的基础点。 首先,我们要明确的了解样式是怎么被渲染的。 具体的...

    lavnFan 评论0 收藏0
  • [译]HTML&CSS Lesson3: 了解CSS

    摘要:我们会在组合选择器中来了解为什么权重值要加连字符。组合选择器中的权重值会分别对不同类型的选择器进行计数。对比两组选择器,第二组选择器有两个选择器,拥有更高的权重值。 CSS是一门复杂的语言,拥有相当的大能力。 它我们允许为页面添加布局和设计,允许多个元素甚至多个页面共享样式。在我们有能力解锁所有功能之前,我们必须先充分理解它的基础点。 首先,我们要明确的了解样式是怎么被渲染的。 具体的...

    soasme 评论0 收藏0
  • 你对CSS权重真的足够了解吗?

    摘要:如果两个权重不同的选择器作用在同一元素上,权重值高的规则生效选择器可能会包含一个或者多个与权重相关的计算点,若经过权重值计算得到的权重值越大,则认为这个选择器的权重高。 前言 css权重很多人都听过,也了解一些,但是很多人对具体的规则或者说再深如一些关于css权重的问题,可能会不那么清楚。日常开发中,或多或少都会遇到css规则不生效的问题,为了让我们能够减少调试css规则的时间,深刻理...

    xioqua 评论0 收藏0
  • 20180224-css选择器的权重

    摘要:选择器的权重第一种情况样式表中只有单一样式即内联元素第二种情况组合选择器从左往右逐个比较,按进行比较越大权重越高。 css选择器的权重showImg(https://segmentfault.com/img/bV4dpB?w=542&h=376); 1第一种情况: 样式表中只有单一样式: 即 内联>id>class>元素 #id{} .class{} p{} 2第二种情况: 组合选择器...

    邹强 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<