CSS 选择器优先级(权重)

一、问题提出?

请问div的背景颜色为红色还是绿色呢?

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		div{
			width: 100px;
			height: 100px;
			background-color: red;
		}
	</style>
</head>
<body>
	<div style="background-color: green;"></div>
</body>
</html>

答案为绿色。为什么会是绿色呢?难道存在代码执行的先后的覆盖问题?请看第二个问题。
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
		div{
			width: 100px;
			height: 100px;
		}
		#demo1{
			background-color: red;
		}
		.demo2{
			background-color: green;
		}
	</style>
</head>
<body>
	<div class="demo2" id="demo1"></div>
</body>
</html>

div的颜色为红色。当设置背景颜色的代码互换后div的背景颜色依然是红色。这说明并不是覆盖问题,读者可以自己试一试。

.demo2{
		background-color: green;
}
#demo1{
		background-color: red;
}

二、问题的解释

在css的样式中存在权重,权重最高的执行相关的代码。
权值是256进制。

相关属性权值相关样例
!importantInfinity#only{background-color: yellow!important;}
行间样式1000p style = “” /p
id100#demo{}
class、属性、伪类10.demo{} 、 、a:hover{}
标签、伪元素1div{} 、::after{}
通配符0*{}

第一个问题中,由于行间样式的权值要比内联样式的权值要高,所以执行行间样式的代码。第二个问题中,由于id的权值要比class权值高,所以执行id的代码。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值