css权重如何计算?

css权重指的是这些选择符的优先级,优先级高的CSS样式会覆盖优先级低的样式。那么css权重如何计算?下面给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

css权重如何计算?

CSS权重是由四个数值决定,看一张图比较好解释:

1.jpg

图里是英文的,我翻译过来分别说一下,4个等级的定义如下:

  • 第一等:内联样式,如:style="color:red;",权值为1000.(该方法会造成css难以管理,所以不推荐使用)

  • 第二等:ID选择器,如:#header,权值为0100.

  • 第三等:类、伪类、属性选择器如:.bar, 权值为0010.

  • 第四等:标签、伪元素选择器,如:div ::first-line 权值为0001.

最后把这些值加起来,再就是当前元素的权重了。

其他:

  • 无条件优先的属性只需要在属性后面使用!important。它会覆盖页面内任何位置定义的元素样式。(ie6支持上有些bug)。

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

  • 继承的样式没有权值。

CSS权重计算方式

  • 计算选择符中的ID选择器的数量(=a)

  • 计算选择符中类、属性和伪类选择器的数量(=b)

  • 计算选择符中标签和伪元素选择器的数量(=c)

  • 忽略全局选择器

在分别计算a、b、c的值后,按顺序连接abc三个数字组成一个新的数字,改值即为所计算的选择符的权重。如果两个选择符的计算权重值相同,则采取“就近原则”。

示例:

div#app.child[name="appName"] /a=1,b=2,c=1 —>权重 = 1 + 100 + 10 +10 = 121/

更多前端开发知识,请查阅 HTML中文网 !!

以上就是css权重如何计算?的详细内容,更多请关注html中文网其它相关文章!

赞(0) 打赏
未经允许不得转载:html中文网首页 » CSS3 答疑

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

前端开发相关广告投放 更专业 更精准

联系我们

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏