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。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: CSS设置!important可以使样式具有最高的优先级,即使其他样式具有更高的特定性或来源。这是因为!important会覆盖任何其他样式,除非它们也使用了!important。但是,应该谨慎使用!important,因为它可能会导致样式表难以维护和调试。 ### 回答2: CSS权重用于确定应用样式的优先级顺序。important是一种特殊的权重,用于覆盖其他样式规则。 在CSS,important的权重是最高的。不论其他样式规则具有多高的权重,使用了important关键字的样式规则都会最终应用于元素。 可以将important关键字添加到样式规则的声明,例如: ```css p { color: blue !important; } ``` 上述代码,所有的段落元素将被设置为蓝色,即使有其他样式规则也设置了颜色。 然而,虽然important具有最高的权重,但滥用它可能会导致问题。因为important会使样式规则具有更高的优先级,当样式冲突时,可能会导致难以预料的结果。因此,建议只在必要的情况下使用important,并尽量避免过多使用。 总结起来,CSS的important是一种特殊的权重,可以用于覆盖其他样式规则。虽然它具有最高的权重,但滥用它可能会导致问题。在编写CSS样式时,应谨慎使用important,并确保理解其使用方式和影响。 ### 回答3: 在CSS权重用于确定应用于元素的样式规则的优先级。有时候,我们希望某些样式规则具有最高的优先级,以覆盖其他规则。这时候,我们可以使用!important关键字来设置样式规则的权重最高。 !important关键字可以应用于任何CSS样式规则的属性值之后。它告诉浏览器,无论其他规则的权重如何,这个样式规则必须优先于其他规则应用于元素。 !important是一个很有用的工具,但我们应该谨慎使用它。滥用!important可能导致代码失去可维护性和可读性。如果我们经常需要使用!important来覆盖其他规则,那可能意味着我们的CSS选择器或规则有问题,需要优化。 为了正确理解样式规则的权重,我们需要了解不同选择器和声明对权重的影响。一般来说,ID选择器的权重比类选择器高,类选择器的权重比标签选择器高。另外,内联样式(即直接在HTML元素内部使用style属性)的权重最高。 如果我们发现其他规则具有更高的权重,并且我们希望特定的规则优先应用,可以使用!important来提高权重。例如: ``` p { color: red !important; } ``` 上述代码,所有的段落都将被设置为红色,无论其他规则如何。 总结来说,CSS!important关键字用于设置样式规则的权重最高。但我们应该谨慎使用它,避免滥用,以保持代码的可维护性和可读性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Jonny Jiang-zh

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

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

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

打赏作者

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

抵扣说明:

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

余额充值