CSS样式特异性5层次详解

你好,我是云桃桃。

一个希望帮助更多朋友快速入门 WEB 前端的程序媛。

云桃桃-大专生,一枚程序媛,感谢关注。回复 “前端基础题”,可免费获得前端基础 100 题汇总,回复 “前端工具”,可获取 Web 开发工具合集

293篇原创内容-更多前端系列内容可以go公众.h:云桃桃

后台回复“前端工具”可获取开发工具,持续更新中

后台回复“前端基础题”可得到前端基础100题汇总,持续更新中

后台回复“前端电子书”可获取20+本精选电子书

前言

在 CSS 中,特异性(Specificity)是一个决定页面中哪些样式规则应用到特定元素的规则集。当多个规则都适用于同一个元素时,特异性决定了哪个规则将被应用。理解特异性对于编写清晰、可预测的 CSS 代码至关重要。

那我们一起来看看吧。

特异性的层次

特异性有 5 个层次,从高到低依次是:

  • 内联样式:直接在 HTML 元素的style属性中声明的样式,特异性最高。

  • ID 选择器:使用#定义的,如#header

  • 类选择器、属性选择器和伪类:使用.定义的类选择器,如.highlight,使用[attribute]定义的属性选择器,如[type="text"],以及伪类,如:hover

  • 元素和伪元素选择器:元素选择器,如pdiv,以及伪元素选择器,如::before

  • 通用选择器(*):*。

也就是一个优先级公式:内联样式 > ID 选择器 > 类选择器、伪类、属性选择器 > 元素选择器、伪元素选择器 > 通用选择器(*)

假设我们有以下 CSS 规则:

p {color: blue;
}#main p {color: green;
}p.highlight {color: red;
}

效果如下:

图片

也就是说,如果一个<p>元素同时拥有id="main"class="highlight",那么它的文本颜色将会是绿色,因为 ID 选择器的特异性高于元元素和类选择器。

计算特异性的规则

特异性是通过计算每个选择器的层次值来确定的。具体来说,特异性的计算规则如下:

  • 内联样式:加 1000 个特异性值。

  • ID 选择器:每个 ID 加 100 个特异性值。

  • 类、属性和伪类选择器:每个类、属性或伪类加 10 个特异性值。

  • 元素和伪元素选择器:每个元素或伪元素加 1 个特异性值。

  • 通用选择器(*):加 0 个特异值。

如果有多个选择器,它们的特异性值会相加。

例子:以下 CSS 规则,如注释说明,所以文字显示的是,蓝色。

/* 特异性:101 */
#content p {color: green;
}/* 特异性:11 */
p.highlight {color: red;
}
<div class="content"><!-- 特异性 1000 --><p class="highlight" style="color: blue">This is text.</p>
</div>

特异性是 CSS 中一个复杂但功能强大的概念。掌握了特异性,你就可以更精确地控制页面的样式,避免许多常见的样式冲突问题。

那如果两个或更多具有相同特异性的样式规则应用于同一个元素时,是什么规则呢?遵循以下 2 点:

  • 后者优先:如果有多个相同特异性的规则,最后一个出现的规则会生效。

  • 重要的是优先:如果使用了!important,则该规则会覆盖其他所有非!important规则,它的特异值可以理解为是 10000。比如,上面 css 的最后我们再加入一个规则。

/* 特异性:10001 = p标签是1 + important是10000 */
p {background-color: #13dada;font-size: 20px;color: #fff !important;
}

效果就会变成我们新写的样式了。

图片

虽然!important在 CSS 中是一个强大的声明,它允许你强制浏览器忽略掉其他所有 CSS 规则,使得使用!important的样式规则具有最高优先级。然而,!important也被认为是一种万不得已的糟糕做法...

为什么不建议用 important?

因为它违背了 CSS 的层叠性(Cascading)和特异性原则,使得样式表难以维护和理解。以下是一些可能会考虑使用!important的情况:

  1. 临时覆盖:在紧急情况下快速修复问题,尤其是当你没有时间或权限去修改更具体的选择器或结构时。

  2. 第三方样式覆盖:有时你可能需要覆盖第三方库或框架的样式,而这些样式往往使用了非常具体的选择器。在这种情况下,使用!important可能是一个折衷方案。

  3. 交互状态:在某些情况下,为了确保元素在特定交互状态下(如:hover:active:focus)的样式表现,开发者可能会使用!important

  4. JavaScript 生成的样式:如果 JavaScript 动态生成的样式与 CSS 有冲突,有时候不得不使用!important来确保样式被应用。

  5. 特定类型的修复:在一些罕见的情况下,可能需要修复浏览器的特定 bug 或兼容性问题,这时可能会用到!important

尽管有上述情况,通常建议尽可能避免使用!important。如果发现自己需要频繁使用!important,这通常是一个信号,表明 CSS 代码需要重构。

更好的做法是使用更具体的选择器、利用 CSS 的层叠性原则,或者重新考虑 HTML 结构来自然地达到所需的样式效果。

OK,以上本文完。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/660301.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于OpenCv的图像基本操作

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

「C/C++ 01」类型转换与整型提升

目录 一、类型转换和截断问题 1. 隐式类型转换 2. 强制类型转换 3. 截断问题 二、整型提升 0. 算数表达式的计算过程 1. 整型提升是什么&#xff1f; 2. 为什么要整型提升&#xff1f; 3. 如何进行整型提升 4. 唯一的注意事项 5. 通过在vs中的监视窗口来观察整型提升 6. 整型…

PotatoPie 4.0 实验教程(36) —— FPGA实现摄像头图像二值化开运算效果

手机扫码 链接直达 https://item.taobao.com/item.htm?ftt&id776516984361 什么是图像开运算&#xff0c;有什么作用&#xff1f; 图像开运算是数学形态学中的一种图像处理操作&#xff0c;它由两个基本操作组成&#xff1a;腐蚀&#xff08;Erosion&#xff09;和膨胀…

73、栈-柱状图中最大的矩形

思路&#xff1a; 矩形面积&#xff1a;宽度*高度 高度如何确定呢&#xff1f;就是在宽度中最矮的元素。如何确定宽度&#xff0c;就是要确定左右边界。 当我们在处理直方图最大矩形面积问题时&#xff0c;遇到一个比栈顶柱子矮的新柱子时开始计算面积的原因关键在于如何确定…

opencv基础篇 ——(十)非真实感渲染

非真实感渲染&#xff08;Non-Photorealistic Rendering, NPR&#xff09;是指通过一系列图像处理技术&#xff0c;将真实感图像转换为具有特定艺术风格或视觉效果的图像&#xff0c;模拟绘画、素描、卡通等非现实主义表现手法。OpenCV 提供了一些内置函数来实现非真实感渲染&a…

74、堆-数组中的第K个最大元素

思路&#xff1a; 直接排序是可以的&#xff0c;但是时间复杂度不符合。可以使用优先队列&#xff0c;代码如下&#xff1a; class Solution {public int findKthLargest(int[] nums, int k) {if (numsnull||nums.length0||k<0||k>nums.length){return Integer.MAX_VAL…

全域团购外卖SAAS系统是什么?

随着多家互联网平台的团购外卖板块逐渐稳定&#xff0c;不少人不再满足于只做1~2个平台的团购外卖服务商&#xff0c;想要拓宽业务范围。在此背景下&#xff0c;全域团购外卖SAAS应运而生&#xff0c;进一步推动了全域团购外卖的流行。 而所谓全域团购外卖&#xff0c;就是指所…

Android Perfetto 监控应用启动耗时

Perfetto 是一个 Google 开发的用于安卓系统性能监控和调试的工具&#xff0c;它旨在提供实时数据收集和可视化功能&#xff0c;帮助我们分析和优化应用程序的性能表现。Perfetto 可以捕获系统事件、CPU、内存、网络、GPU 等性能指标数据&#xff0c;并将其记录为轻量级的 Trac…

链表刷题集

文章目录 概要反转链表代码Python代码C 环形链表代码Python代码Java 小结 概要 这个主要记录下刷的一些题。 链表已经看过了&#xff0c;之前写了篇链表的文章&#xff0c;这一篇&#xff0c;写点跟链表有关的题。主要是leetcode上的。目的是熟悉下代码&#xff0c;代码这东西…

2024 JAVA Tinypng压缩图片,超级简单!!!

一、打开官网&#xff0c;注册账号&#xff0c;获取秘钥&#xff08;每个月500张免费&#xff09; 1.打开官网&#xff0c;注册账号 TinyPNG – Compress WebP, PNG and JPEG images intelligently 2.登录后&#xff0c;点击账号名字&#xff0c;找到如图所示 3.找到API&…

当众演讲技巧的方法有哪些(3篇)

当众演讲技巧的方法有哪些&#xff08;3篇&#xff09; 当众演讲技巧的方法有很多&#xff0c;下面我将分三篇来详细阐述其中的一些关键技巧&#xff1a; **篇&#xff1a;准备与开场技巧 充分准备&#xff1a;提前规划演讲内容&#xff0c;明确主题和目标&#xff0c;准备详…

螺旋角和导程、转位后的齿轮有什么关系?

最近和小伙伴聊到了一个问题&#xff1a;斜齿轮螺旋角和导程的关系&#xff0c;主要是在遇到在采用转位设计方式的刀具时&#xff0c;更觉得有点迷惑&#xff0c;今天咱们就聊聊这个事儿。 先来说斜齿轮螺旋角和导程的关系&#xff1a; 斜齿轮是有多个螺旋面组成的&#xff0…