CSS 基础:层叠、优先级与继承

devtools/2025/2/6 2:44:39/

CSS 基础:层叠、优先级与继承

    • 一、层叠(Cascade)
      • 示例:层叠的顺序
    • 二、优先级(Specificity)
      • 优先级规则
      • 示例:优先级的比较
    • 三、继承(Inheritance)
      • 哪些属性会被继承?
      • 示例:继承的效果
    • 四、控制继承
      • 示例:控制继承
    • 五、优先级的计算
      • 示例:优先级的计算
    • 六、内联样式与 `!important`
      • 示例:`!important` 的使用
    • 七、总结

在学习 CSS 的过程中,层叠、优先级和继承是三个非常重要的概念。它们决定了 CSS 样式如何被应用到 HTML 元素上,以及如何处理样式冲突。本文将通过通俗易懂的语言和实际示例,帮助你理解这些概念。


一、层叠(Cascade)

层叠是 CSS 的核心概念之一。简单来说,层叠指的是 CSS 样式规则的顺序会影响最终的样式效果。当多个规则应用于同一个元素时,最后定义的规则会覆盖前面的规则。

示例:层叠的顺序

<h1>这是我的标题。</h1>
css">h1 {color: red;
}
h1 {color: blue;
}

在这个示例中,<h1> 元素的文本颜色会显示为蓝色,因为后面的规则覆盖了前面的规则。


二、优先级(Specificity)

当多个规则应用于同一个元素时,优先级决定了哪个规则会被应用。优先级由选择器的“具体程度”决定,具体程度越高,优先级就越高。

优先级规则

  1. ID 选择器 > 类选择器 > 元素选择器
  2. 组合选择器(如 div p)的优先级高于单个选择器(如 p
  3. 内联样式(style 属性)的优先级最高

示例:优先级的比较

<h1 class="main-heading">这是我的标题。</h1>
css">.main-heading {color: red;
}h1 {color: blue;
}

在这个示例中,.main-heading 是类选择器,优先级高于元素选择器 h1,所以文本颜色会显示为红色。


三、继承(Inheritance)

继承是指某些 CSS 属性会从父元素传递到子元素。继承可以减少重复代码,但需要注意并不是所有属性都会被继承。

哪些属性会被继承?

  • 会被继承的属性colorfont-familyfont-size
  • 不会被继承的属性widthheightmarginpadding

示例:继承的效果

<ul><li>项目 1</li><li>项目 2<ul><li>2.1</li><li>2.2</li></ul></li>
</ul>
css">ul {color: blue;font-size: 20px;
}

在这个示例中,所有 <li> 元素的文本颜色和字体大小都会继承自父元素 <ul>


四、控制继承

CSS 提供了一些特殊值来控制继承行为:

  • inherit:显式地继承父元素的属性值
  • initial:将属性值设置为初始值
  • unset:如果属性可以继承,则使用父元素的值;否则使用初始值
  • revert:将属性值重置为浏览器默认值

示例:控制继承

<ul><li>默认颜色</li><li class="inherit">继承颜色</li><li class="initial">初始颜色</li><li class="unset">取消设置</li>
</ul>
css">ul {color: green;
}.inherit {color: inherit;
}.initial {color: initial;
}.unset {color: unset;
}

在这个示例中:

  • .inherit 会继承父元素的绿色
  • .initial 会使用初始颜色(黑色)
  • .unset 会继承父元素的绿色

五、优先级的计算

优先级由三个部分组成,按重要性排序如下:

  1. ID 选择器:每个 ID 选择器得 1 分
  2. 类选择器:每个类选择器、属性选择器或伪类得 1 分
  3. 元素选择器:每个元素选择器或伪元素得 1 分

示例:优先级的计算

<div class="container" id="outer"><div class="container" id="inner"><ul><li class="nav"><a href="#"></a></li><li class="nav"><a href="#"></a></li></ul></div>
</div>
css">/* 优先级:1-0-1 */
#outer a {background-color: red;
}/* 优先级:2-0-1 */
#outer #inner a {background-color: blue;
}

在这个示例中,#outer #inner a 的优先级高于 #outer a,因为前者有两个 ID 选择器。


六、内联样式与 !important

  • 内联样式:直接在 HTML 元素上定义的样式,优先级最高。
  • !important:可以强制覆盖所有样式,但应谨慎使用。

示例:!important 的使用

<p class="better">这是个段落。</p>
<p class="better" id="winning">一个选择器掌管一切!</p>
css">#winning {background-color: red;border: 1px solid black;
}.better {background-color: gray;border: none !important;
}

在这个示例中,.betterborder: none !important 会覆盖 #winningborder: 1px solid black


七、总结

  • 层叠:样式规则的顺序会影响最终效果。
  • 优先级:选择器的“具体程度”决定了优先级。
  • 继承:某些属性会从父元素传递到子元素。

理解这些概念可以帮助你更好地控制 CSS 样式,避免样式冲突和意外效果。


http://www.ppmy.cn/devtools/156429.html

相关文章

Linux 文件和目录

Linux 文件和目录 文章目录 Linux 文件和目录Linux 目录Linux 目录配置的依据 --FHS目录树文件属性文件的分类一般权限 UGO特殊权限 suid\sgid\sticky隐藏属性 ATTR文件访问控制列表 ACL文件相关的命令权限的修改 chmod chown chgrp umaskchmodchgrpumask相关文档 /etc/profile…

独立开发经验谈:如何借助 AI 辅助产品 UI 设计

我在业余时间开发了一款自己的独立产品&#xff1a;升讯威在线客服与营销系统。陆陆续续开发了几年&#xff0c;从一开始的偶有用户尝试&#xff0c;到如今线上环境和私有化部署均有了越来越多的稳定用户&#xff0c;在这个过程中&#xff0c;我也积累了不少如何开发运营一款独…

TensorFlow 与 PyTorch 的直观区别

背景 TensorFlow 与 PyTorch 都是比较流行的深度学习框架。tf 由谷歌在 2015 年发布&#xff0c;而 PyTorch 则是 Facecbook AI 研究团队 2016 年在原来 Torch 的基础上发布的。 tf 采用的是静态计算图。这意味着在执行任何计算之前&#xff0c;你需要先定义好整个计算图&…

CSS 图像、媒体和表单元素的样式化指南

CSS 图像、媒体和表单元素的样式化指南 1. 替换元素&#xff1a;图像和视频1.1 调整图像大小示例代码&#xff1a;调整图像大小 1.2 使用 object-fit 控制图像显示示例代码&#xff1a;使用 object-fit 2. 布局中的替换元素示例代码&#xff1a;Grid 布局中的图像 3. 表单元素的…

Android-音频采集

前言 音视频这块&#xff0c;首先是要先采集音频。今天我们就来深入探讨一下 Android 音频采集的两大类型&#xff1a;Mic 音频采集和系统音频采集。 Mic音频采集 Android提供了两个API用于实现录音功能&#xff1a;android.media.AudioRecord、android.media.MediaRecorder。…

LeetCode --- 434周赛

目录 3432. 统计元素和差值为偶数的分区方案 3433. 统计用户被提及情况 3434. 子数组操作后的最大频率 3435. 最短公共超序列的字母出现频率 一、统计元素和差值为偶数的分区方案 本题可以直接模拟&#xff0c;当然我们也可以来从数学的角度来分析一下这题的本质 设 S S S …

CF 761A.Dasha and Stairs(Java实现)

题目分析 大概意思是输入偶数值奇数值&#xff0c;判断是否能够凑成一连串数字 思路分析 能够连成一串数字的条件考虑&#xff1a;1.偶数与奇数差为1&#xff1b;2.偶数与奇数相等&#xff0c;且不为0 代码 import java.util.*;public class Main {public static void…

「AI学习笔记」深度学习进化史:从神经网络到“黑箱技术”(三)

在这篇文章中&#xff0c;我们将探讨深度学习&#xff08;DL&#xff09;这一领域的最新发展&#xff0c;以及它如何从传统机器学习&#xff08;ML&#xff09;中独立出来&#xff0c;成为一个独立的生态系统。深度学习的核心思想与我们大脑中的神经网络高度相似&#xff0c;因…