CSS 属性值的计算过程中。其中第2步层叠冲突只是简单说明了下,这篇文章来详细介绍。
为什么叫层叠冲突,可以理解为 CSS 是 Cascading Style Sheets 的缩写,这里面有层叠(cascade)的概念。
选择器会进行组合,所以才有了优先级规则。主要有3个规则,前一种会直接否决后一种。
1,重要性
但我在张鑫旭老师的著作《CSS世界》中发现,就最终结果而言,!important
也有可能会被覆盖!那就是 max-width
和 max-height
。
<style>
.box {
width: 200px !important;
max-width: 100px;
height: 100px;
background-color: salmon;
}
</style>
<div class="box"></div>
表现:
2,专用性
用来衡量选择器的具体程度,主要是指它能匹配多少元素,匹配的越少专用性越高。
基础专用性(优先级):行内样式 > id选择器 > class选择器 > 元素选择器。
- 千位:如果声明在 style 属性中,该列加 1 分(相当于没有选择器,所以它们的专用性总是 1000)否则为 0。
- 百位:在整个选择器中每包含一个 ID 选择器,该列就加 1 分。
- 十位:在整个选择器中每包含一个类选择器、属性选择器、或者伪类,该列就加 1 分。
- 个位:在整个选择器中每包含一个元素选择器或伪元素,该列就加 1 分。
选择器 | 千位 | 百位 | 十位 | 个位 | 合计值 | 备注 |
---|---|---|---|---|---|---|
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 |
注意点:
3,源代码顺序
以上。
原文地址:https://blog.csdn.net/qq_40147756/article/details/134758113
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_31804.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。