CSS样式优先级怎样划分?【CSS优先级规则】

news2024/12/25 13:16:08

定义CSS样式时,经常出现两个或更多样式规则应用在同一元素上的情况。此时CSS就会根据样式规则的权重,优先显示权重最高的样式。CSS优先级指的就是CSS样式规则的权重。在网页制作中,CSS为每个基础选择器都指定了不同的权重,方便我们添加样式代码。为了深入理解CSS优先级,我们通过一段示例代码进行分析。CSS样式代码如下:

p{ color:red;}           /*标签样式*/
.blue{ color:green;}     /*class样式*/
theader{ color:blue;}    /*id样式*/

CSS样式代码对应的HTML结构为:

<p class="blue" id="header">
    帮帮我,我到底显示什么颜色?
</p>

在上面的示例代码中,使用不同的选择器对同一个元素设置文本颜色,这时浏览器会根据CSS选择器的优先级规则解析CSS样式。为了便于判断元素的优先级,CSS为每一种基础选择器都分配了一个权重,我们可以通过虚拟数值的方式为这些基础选择器匹配权重。假设标签选择器具有权重为1.类选择器具有权重则为10,id选择器具有权重则为l00。这样id选择器“#header”就具有最大的优先级,因此文本显示为蓝色。

对于由多个基础选择器构成的复合选择器(并集选择器除外),其权重可以理解为这些基础选择器权重的叠加。例如,下面的CSS代码。

p strong{color:black}            /*权重为:1+1*/
strong.blue{color:green;}        /*权重为:1+10*/
.father strong{color:yellow}     /*权重为:10+1*/
p.father strong{color:orange;}   /*权重为:1+10+1*/
p.father .blue{color:gold;}      /*权重为:1+10+10*/
theader strong{color:pink;}      /*权重为:100+1*/
#header strong.blue{color:red;}  /*权重为:100+1+10*/

对应的HTML结构为:

<p class="father" id="header">
    <strong class="blue">文本的颜色</strong>
</p>

这时,CsS代码中的“#header strong.blue”选择器的权重最高,文本颜色将显示为红色。此外,在考虑权重时,我们还需要注意一些特殊的情况。

(1)继承样式的权重为0

在嵌套结构中、h不管父元素样式的权重多大,被子元素继承时,它的权重都为0,也就是说子元素定义的样式会覆盖继承来的样式。例如,下面的CSS样式代码。

strong{color:red;}
#header{color:green;}

CSS样式代码对应的HTML结构如下:

<p id="header" class="blue">
  <strong>继承样式不如自己定义的权重大</strong>
</p>

在上面的代码中,虽然“#header”具有权重100,但被标签继承时权重为0。而“strong”选择器的权重虽然仅为1,但它大于继承样式的权重,所以页面中的文本显示为红色。

(2)行内样式优先

应用style属性的元素,其行内样式的权重非常高。换算为数值,我们可以理解为远大于100。因此行内样式拥有比上面提到的选择器都高的优先级。

(3)权重相同时,CSS的优先级遵循就近原则

也就是说,靠近元素的样式具有最大的优先级,或者说按照代码排列上下顺序,排在最下边的样式优先级最大。例如,下面为外部定义的CSS示例代码。

/*CSS文档,文件名为style_red.css*/
#header{color:red;}                     /*外部样式*/

对应的HTML结构代码如下:

<title>CSS优先级</title>
<link rel="stylesheet"href="style_red.css"type="text/css"/> /*引入外部
定义的CSS代码*/
<style type="text/css">
#header{color:gray;}
</style>
</head>
<body>
/*内嵌式样式*/
<p id="header">权重相同时,就近优先</p>
</body>

在上面的示例代码中,第2行代码通过外链式引入CSS样式,该样式设置文本样式显示为红色。第3~5行代码通过内嵌式引入CSS样式,该样式设置文本样式显示为灰色。

上面的页面被解析后,段落文本将显示为灰色,即内嵌式样式优先。这是因为内嵌样式比外链式样式更靠近HTML.元素。同样的道理,如果同时引用两个外部样式表,则排在下面的样式表具有较大的优先级。如果此时将内嵌样式更改为:

p{color:gray;}                   /*内嵌式样式*/

此时外链式的id选择器和嵌入式的标签选择器权重不同,“#header”的权重更高,文字将显示为外部样式定义的红色。

(4)CSS定义“limportant”命令,会被赋予最大的优先级

当CSS定义了“limportant”命令后,将不再考虑权重和位置关系,使用“limportant”的标签都具有最大优先级。例如,下面的示例代码。

#header{color:red!important;}

应用此样式的段落文本显示为红色,因为“limportant”命令的样式拥有最大的优先级。需要注意的是,“limportant”命令必须位于属性值和分号之间,否则无效。

复合选择器的权重为组成它的基础选择器权重的叠加,但是这种叠加并不是简单的数字之和。下面通过一个案例来具体说明,如例1所示。

例1 examplel1.html

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>复合选择器权重的叠加</title>
<style type="text/css">
.inner{text-decoration:line-through;}/*类选择器定义删除线,权重为10*/
div div div div div div div div div div div{text-decoration:underline;}
/*后代选择器定义下画线,权重为11个1的叠加*/
 </style>
</head>
<body>
<div>
  <div><div><div><div><div><div><div><div><div>
     <div class="inner">文本的样式</div>
  </div></div></div></div></div></div></div></div></div>
</div>
</body>
</html>

例1共使用了11对

标签,它们层层嵌套。第15行代码我们对最里层的
定义类名“inner”。第7、8行代码,使用类选择器和后代选择器分别定义最里层div的样式。此时浏览器中文本的样式到底如何显示呢?如果仅仅将基础选择器的权重相加,后代选择器(包含11层div)的权重为11,大于类选择器“.inner”的权重10,文本将添加下画线。

运行例1,效果如下所示。

1670579654196_复合选择器.png

在上图中,文本并没有像预期的那样添加下画线,而显示了类选择器“.inner”定义的删除线。可见,无论在外层添加多少个标签,复合选择器的权重无论为多少个

标签选择器的叠加,其权重都不会高于类选择器。同理,复合选择器的权重无论为多少个类选择器和标签选择器的叠加,其权重都不会高于i选择器。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【内存问题真的很烦人】linux内存等资源管理 以及 linux内存不足解决办法

linux内存不足解决办法 ///这一部分存在疑问 查看目录下文件夹大小 du -h --max-depth1 看具体哪个文件夹占用内存过高&#xff0c;一般是日志&#xff0c;删除即可。 ///这一部分存在疑问&#xff0c;上面的文件夹可以代表内存吗&#xff1f; 内存不够 top 命令 看内存占用…

Python就业前景如何?三大就业岗位分享

Python是一门面向对象的编程语言&#xff0c;编译速度超快&#xff0c;从诞生到现在已经20来个年头了。Python的排名从去年开始就借助人工智能持续上升&#xff0c;Python的火热&#xff0c;也带动了工程师们的就业热。 据统计&#xff0c;现在初级Python工程师的起薪一般在10…

【 Lucas-Kanade光流法】

这里写目录标题 1.1 Lucas-Kanade光流法1.1 Lucas-Kanade光流法详细步骤&#xff1a; 1.1 Lucas-Kanade光流法 Lucas-Kanade光流法是一种密集光流估计方法&#xff0c;用于计算图像中每个像素的运动向量。它假设在相邻帧之间&#xff0c;像素的灰度值不会发生大的变化&#xf…

《网络安全0-100》双钥加密体制

双钥加密体制 怎么说 没找着公钥加密在哪&#xff0c;所以就接着写了。 公钥加密&#xff0c;也叫非对称(密钥)加密&#xff0c;属于通信科技下的网络安全二级学科&#xff0c;指的是由对应的一对唯一性密钥(即公开密钥和私有密钥)组成的加密方法。它解决了密钥的发布和管理…

【ArcGIS】使用ArcGIS进行坡度分析

使用ArcGIS进行坡度分析 1 数据来源2 操作步骤参考 坡度是指过地表面任意一点的切平面与水平地面之间的夹角。坡度用来计算任–单元和邻域单元间变化的最大比率&#xff0c;如单元下降最陡的坡面(单元和它相邻单元间的高程距离的最大变化率)。 坡度分析是计算两相邻像元间的数值…

STM32的时钟系统(嵌入式学习)

STM32的时钟系统 时钟的基本概念时钟系统的组成时钟源晶体振荡器和RC振荡器的区别晶体振荡器RC振荡器 STM32G030时钟源时钟树STM32CubeMX时钟树配置 时钟的基本概念 时钟是指用于计量和同步时间的装置或系统。时钟是嵌入式系统的脉搏&#xff0c;处理器内核在时钟驱动下完成指…

Goby 漏洞发布|PandoraFMS 软件 upload_head_image.php 任意文件上传漏洞

漏洞名称&#xff1a;PandoraFMS 软件 upload_head_image.php 任意文件上传漏洞 English Name&#xff1a;PandoraFMS upload_head_image.php Arbitrary File Upload Vulnerability CVSS core: 9.0 影响资产数&#xff1a;768 漏洞描述&#xff1a; PandoraFMS是美国Pando…

【Python】文件操作 ④ ( 文件操作 | 向文件写出数据 | 使用 write 函数向文件中写出数据 | 使用 flush 函数刷新文件数据 )

文章目录 一、向文件写出数据1、使用 write 函数向文件中写出数据2、使用 flush 函数刷新文件数据3、代码示例 - 使用 write / flush 函数向文件中写出数据 一、向文件写出数据 1、使用 write 函数向文件中写出数据 Python 中 通过 调用 write 函数 向文件中写入数据 ; 语法如下…

Fiddler抓包工具之fiddler的常用快捷键

一、常用三个快捷键 ctrlX :清空所有记录 CtrlF&#xff1a;查找 F12&#xff1a;启动或者停止抓包 使用 QuickExec Fiddler2 成了网页调试必备的工具&#xff0c;抓包看数据。Fiddler2自带命令行控制。 fiddler 命令行快捷键&#xff1a;ctrl q &#xff0c;然后 输入 help…

记一次杀猪盘网站渗透

1、首先访问杀猪盘主站。 2、通过扫描子域名找到后台管理系统。 3、对其后台的登录接口进行测试&#xff0c;发现接口的用户名参数存在sql注入&#xff0c;直接跑数据。 4、注入得到后台的账密如下,用户名和safecode是明文的&#xff0c;password使用自定义加密。 跑出来了账号…

PaaS2.0、Matter、AIGC、新能源…TUYA开发者大会亮点抢先看

6月29日&#xff0c;TUYA开发者大会&#xff08;深圳&#xff09;即将开幕。作为业内备受关注的盛会&#xff0c;大会的各种“路透”消息络绎不绝。那么TUYA开发者大会将呈现哪些精彩&#xff0c;我们带大家一探究竟。 亮点1&#xff1a;IoT行业风向标 积蓄2年的硬核分享 TUYA…

【Ribbon实现客户端负载均衡和故障转移】—— 每天一点小知识

&#x1f4a7; R i b b o n 实现客户端负载均衡和故障转移 \color{#FF1493}{Ribbon实现客户端负载均衡和故障转移} Ribbon实现客户端负载均衡和故障转移&#x1f4a7; &#x1f337; 仰望天空&#xff0c;妳我亦是行人.✨ &#x1f984; 个人主页——微风撞见云的博客…

掌握会议任务追踪技巧,提高会议效率!

跟踪会议任务是有效项目管理的重要组成部分。会议可以产生许多需要完成的行动项目和任务&#xff0c;如果没有适当的跟踪&#xff0c;这些任务很容易被遗漏。在本文中&#xff0c;我们将概述如何有效地跟踪会议任务。 1、在会议中分配任务 在会议期间&#xff0c;将任务分配给特…

眼球交互vs眼疲劳,前Vision Pro设计师揭秘这些细节

Vision Pro的发布带来了众多讨论&#xff0c;从交互层面来看&#xff0c;它真正的将AR/VR的首选交互从手柄转移到手势眼球上面来&#xff0c;此前的AR、VR大部分还是通过手柄来完成交互&#xff08;HoloLens除外&#xff09;&#xff0c;手势交互是它们的第二选择。 交互方式主…

leetcode847. 访问所有节点的最短路径

847. 访问所有节点的最短路径 状态压缩 这是一个等权无向图&#xff0c;题目要我们求从「一个点都没访问过」到「所有点都被访问」的最短路径。 同时1 < n < 12, n 最大只有 12&#xff0c;容易想到使用「状态压缩」来代表「当前点的访问状态」&#xff1a;使用二进制表…

Windows下部署Appium教程(Android App自动化测试框架搭建)

摘要: 1&#xff0c;appium是开源的移动端自动化测试框架&#xff1b; 2&#xff0c;appium可以测试原生的、混合的、以及移动端的web项目&#xff1b; 3&#xff0c;appium可以测试ios、android、firefox os&#xff1b; 4&#xff0c;appium是跨平台的&#xff0c;可以用在os…

【系统开发】尚硅谷 - 谷粒商城项目笔记(七):消息队列

文章目录 消息队列概述两大种类RabbitMQ安装及基操Docker中安装添加用户创建Virtual Hosts设置权限添加交换机创建队列交换机绑定队列 五种消息模型SpringBoot整合MQ引入依赖properties配置开启RabbitMQ API使用创建交换机创建队列交换机绑定队列发送消息接收消息 消息确认机制…

Notification API实战

什么是Notification&#xff1f; Notifications API 的接口 Notification 用于配置以向用户显示桌面通知。 这些通知的外观和功能因平台而异&#xff0c;但通常它们会提供一种异步向用户提供信息的方式。 前置要求 win10系统&#xff0c;且通知与操作中开启浏览器的通知权限 浏…

学习 SSL/TLS ,这一篇就够了

写在前面 如果某个网站受 SSL 证书保护&#xff0c;其相应的 URL 中会显示 HTTPS&#xff08;超文本传输安全协议&#xff09;。单击浏览器地址栏的小绿锁&#xff0c;即可查看证书中的详细信息。那么一本证书是如何诞生的&#xff1f;HTTPS 背后的 SSL/TLS 是如何在工作过程中…

❤ vue3 组件传值

❤ vue3 组件传值 [1] 子组件向父组件传值 使用emit使用方法 【子组件】 1、定义 emits,emits的定义是与component、setup等这些属性是同级 emits此时是作为数组&#xff0c;它也可以接收一个对象 2、使用 setup(props, { emit, refs }) {emit(addImg, 参数); }有时候需使…