CSS 属性值的计算过程中。其中第2步层叠冲突只是简单说明了下,这篇文章来详细介绍

层叠冲突更广泛的被称为 CSS选择器优先级计算

为什么层叠冲突,可以理解为 CSS 是 Cascading Style Sheets 的缩写,这里面有层叠(cascade)的概念

选择器会进行组合,所以才有了优先级规则。主要有3个规则,前一种会直接否决后一种。

1,重要性

只有一条规则!important,总是优先于其他规则

但我在张鑫旭老师的著作《CSS世界》中发现,就最终结果而言,!important 也有可能会被覆盖!那就是 max-widthmax-height

示例

<style>
  .box {
    width: 200px !important;
    max-width: 100px;
    height: 100px;
    background-color: salmon;
  }
</style>

<div class="box"></div>

表现:

在这里插入图片描述

!important 需要谨慎使用,会对维护造成困难。

2,专用性

用来衡量选择器的具体程度,主要是指它能匹配多少元素匹配的越少专用性越高

基础专用性(优先级):行内样式 > id选择器 > class选择器 > 元素选择器。

选择组合需要更精细的来衡量,也就是权重

选择器 千位 百位 十位 个位 合计 备注
h1 0 0 0 1 0001
#id 0 1 0 0 0100
h1 + p::first-letter 0 0 0 3 0003
li > a[href*=” zh-CN”] > .box 0 0 2 2 0022 元素选择器是 li 和 a
内联样式 1 0 0 0 1000

注意点

  1. 进制是 256 进制,不是10进制这个无法求证,参考其他文章的)。
  2. 通配符选择器(*), 复合选择器(+、>、~、空格)和否定伪类:not)在专用性中无影响

3,源代码顺序

如果选择器有相同的重要性和专用性,则看源代码顺序


以上。

原文地址:https://blog.csdn.net/qq_40147756/article/details/134758113

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_31804.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注