对CSS样式优先级的理解

概念:定义CSS样式时,经常出现两个或更多规则应用在同一元素上,此时,

  • 选择器相同,则执行层叠性。
  • 选择器不同,就会出现优先级的问题。

权重计算公式

关于CSS权重,我们需要一套计算公式来去计算,这个就是CSS Specificity(特殊性)

标签选择器计算权重公式
通配符(*)0,0,0,0
标签选择器0,0,0,1
class类,伪类0,0,1,0
ID选择器0,1,0,0
行内样式 style=“”1,0,0,0
!important无穷大

**!important** -> 行内样式 -> ID选择器 -> class选择器 -> 标签选择器 -> 通配符选择器

  • specificity用一个四位的数,更像四个级别,
  • 值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越

小练习

<head>
		<meta charset="utf-8">
		<title>css优先级</title>
		<style type="text/css">
			div {
				color: red!important;
			}
			.one {
				color: blue;
			}
			div {
				color: #008000;
			}
			#two {
				color: #7FFFD4;
			}
		</style>
	</head>
	<body>
		<div class="one" id="two" style="color: #FFA500">权重还有30s到达战场</div>
	</body>

容器div中内容会根据不同的权重来显示。

权重的叠加

我们经常用交集选择器,后代选择器,是有多个基础选择器组合而成,就会出现权重叠加。

这是一个简单的加法计算:

  • div ul li --> 0,0,0,3
  • .nav ul li --> 0,0,1,2
  • a:hover --> 0,0,1,1

小结:

  1. 数位之间没有进制 比如说:0,0,0,5+0,0,0,5 = 0,0,0,10 而不是 0,0,1,0 所以不会存在10div能赶上一个类选择器的情况
  2. 继承的权重是 0
  3. 如果权重相同,则会根据层叠性,就近原则。
  4. 存在两个特殊标签 <a></a><h></h>他们在浏览器有自己默认的样式,继承的权重为0,所以,我们还是要单独给链接和标题一个样式。

个人博客已上线,欢迎来访~
传送门:夜雨炊烟

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夜雨炊烟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值