css中的权重问题

css中的权重问题

问题

是否css的加载顺序就一定是:行内 > 内部 > 外部 / id选择器 > class选择器???

本章主要分析css中的权重问题。在我们学习时,经常听说:**样式有三种书写方式,第一种是行内样式,第一种是内部样式,最后一种是外部样式。在我们引入样式的时候,毫无疑问行内样式优先级是最高的,内部样式理所当然会覆盖外部样式。id选择器也会大于class选择器。**当时没有多深究,就信了,在以后一段时间里,就使用这种规则去写代码,是ok的。直到有一次看书时联想到了这个问题,就开始重新测试……

首先,内部样式会覆盖外部样式。

/*test.css*/
#div { color: red; }

<link rel="stylesheet" href="test.css">
<style>
  #div {
    color: yellow;
  }
</style>

<div id='div'>
  <p id='p'>我是测试的</p>
</div>

然后,id选择器 > class选择器

<style>
  #div { color: yellow; }
  .div { color: red; }
</style>

<div id='div' class='div'>
  <p id='p'>我是测试的</p>
</div>

问题即将来临

/*test.css*/
#div { color: red; }

<style>
  #div {
    color: yellow;
  }
</style>
<link rel="stylesheet" href="test.css">    <!-- 在后边引入 -->

<div id="div">
  <p id="p">我是测试的</p>
</div>

不是说好的内部优先级高于外部?按照加载的顺序,后加载的就覆盖之前的,这还可以接受。

但是

<style>
  #div p { color: red; }
  #p { color: yellow; }
</style>

<div id="div" class="div">
  <p id="p">这里是测试文本</p>
</div>

不是说id选择器优先级应该要高于class和tag标签选择器,所以#p的优先级是最高的才是……由此进入主要内容——css权重

概述

css最终显示的样式是由权重决定的,每种选择器都有一个权重值,不管谁先加载或后加载,谁的权重值最大,就显示谁,如果相同,则显示后声明。从0开始,行内样式+1000,id+100,属性选择器/class或者伪类(包括结构伪类选择器)+10,元素名或者伪元素+1。并且做加法时不进位。例如:

#div .test p {}  /* 0111 */
body#container div {}   /* 0102 */
/*相加不进位*/
.p1 .p2 .p3 .p4 .p5 .p6 .p7 .p8 .p9 .p10 .p11 div { color: red; }    /* 0,0,11,1 */
#p1 div { color: yellow; }    /* 0,1,0,1 */  /* 大于上边一行的权重,所以显示黄色的 */

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .p1 .p2 .p3 .p4 .p5 .p6 .p7 .p8 .p9 .p10 .p11 span { color: red; }
        #div span { 
            color: yellow; 
		}
    </style>
</head>
<body>
    <div id="div">
        <p class="p1">
            <p class="p2">
                <p class="p3">
                    <p class="p4">
                        <p class="p5">
                            <p class="p6">
                                <p class="p7">
                                    <p class="p8">
                                        <p class="p9">
                                            <p class="p10">
                                                <p class="p11">
                                                    <span>我是测试的</span>
                                                </p>
                                            </p>
                                        </p>
                                    </p>
                                </p>
                            </p>
                        </p>
                    </p>
                </p>
            </p>
        </p>
    </div>
</body>
</html>

在这里插入图片描述

但是,又是一个新问题。

<!DOCTYPE html>
<html>
<head>
	<title></title>
	<style type="text/css">
		.a::after {
			content: "哈哈哈";
			color: #008000;
		}
		#al .a {
			color: red;
		}
		span {
			color: #00FFFF;
		}
	</style>
</head>
<body>
	<div id="al">
		<div class="a"> 
			<!-- 在这里span继承了父级的样式,权重为0,但是它使用标签选择器设置了自身样式,权重为1,故,颜色不一样,上面的伪元素选择器也是。-->
			<span class="b">哈哈哈哈</span>
			啊啊啊
		</div>
	</div>
</body>
</html>

这个就涉及另一个知识点,子元素从父元素继承而来的css样式权重为0。

总结

  • 将权重想象成一个4位数(0000),初始都为0
  • 行内样式为(1000)
  • id选择器(0100)
  • 类选择器、伪类选择器、属性选择器、结构为类选择器(0010)
  • 标签选择器、伪元素选择器(0001)
  • !important权重最高
  • 从左往右比较,相等则继续,不等则停止,大的权重大
  • 从父级元素继承的选择器的权重为0。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Jonny Jiang-zh

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

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

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

打赏作者

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

抵扣说明:

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

余额充值