标记选择器,类选择器,id选择器,伪类选择器的优先级顺序

2025-04-14 02:11:30
推荐回答(4个)
回答(1):

选择器的优先级顺序

  1. id 级别最高

  2. 其次是伪类

  3. 然后是类

  4. 最低的是元素

下图实例:请看红圈位置不管代码插入的顺序在第几行,他都会按照我数字标注的顺序执行

同类别选择器执行顺序

在我们布局的时候,很常用的就是,一个div使用了多个类,他到底会优先执行那个呢?

我分别设置了三个类:

30行.aaa{背景红色}

31行.bbb{背景黄}

32行.ccc{背景蓝}

执行结果

优先执行了蓝色,我们在调换下代码顺序看看

30行.ccc{背景蓝}

31行.bbb{背景黄}

32行.aaa{背景红}

执行结果

从以上测试我们得出,在设置同一类选择器的情况下,优先级是以代码插入顺序有关的,越靠后的优先级就越高。

原因:在浏览器加载的过程中,是以从上到下的顺序执行的,在加载到最后一个的时候会把之前的替换掉

回答(2):

首先说下曾经踩过的坑,p:nth-child(1) 匹配的是任何元素的第一子元素p ,(之前把它理解成p下的一个元素)
p:nth-of-type(1) 匹配的是任何元素的所有子元素的第一个p


3


4

5


6

p:nth-child(1) 匹配3,如果要匹配第一span 只能是 span:nth-of-type

谈到CSS选择器可能大家最熟悉与常用的就是 标签、id、class选择器了,从效率上来说它们三个无疑最高的选择,我们确实也应优先使用,但在实际开发中,我们可能还有一些友好的选择器,下面列举一些常用css选择器(注意只包括常用有代表性的选择器,部分少用的未列举):
1、基本选择器,效率最高; id 、class、标签、* 通用选择器
2、组合选择器,效率相对来基本选择器来说较低,‘h1,p多类’、‘div p后代’、‘div>p子’、‘div~p 同级’、‘div+p相邻(div同级的后一个元素)’选择器
3、属性选择器,效率相对来说又低一层,E[arr]、E[att^=”val”]、E[att$=”val”]、E[att*=”val”]
4、伪类选择器,效率最低,:hover :active :focus :first-child :checked :enabled :nth-child(n) :nth-of-type(n)
(E:after E:before E:first-letter E:first-line伪元素)
选择器优性能及优化详见 :http://blog.sina.com.cn/s/blog_60bbe8e901011veg.html ,里面写得相当详细(包括CSS解析 ),感谢博主!!!

下面着重介绍选择器优先级,我们都是站在巨人的肩膀上做了一些自己的见解,帮助大家更好的理解它
之前看了网上的其它一些博客,感觉讲得都很繁琐,计算什么权重,感觉都挺官方的,我在这里介绍一些常见的、通俗易懂的方法,



优先级 行内style>id>class>标签, 这是网上博客中一些比较常见的
1、important,大家都知道它的优先级最高,但我在class和id选择器中都设置它,则浏览器会使用哪个呢(答案是 id),在important存在的情况下,它会跳过important,从优先级表从下往下比,找到class与id 并比较优先级
2、

div{
background-color: red;
}
body div{
background:black;
}

背景色是black
3、
.min-screen{
background-color: green;
}
#test{
background: blue;
}
div[data-index='tt']{
background:yellow;
}

显示yellow
4、

.min-screen{
background-color: green;
}
div[data-index='tt']{
background:yellow;
}
div:nth-child(1){
background:palegreen;
}
显示palegreen, 当加上 #test{background: blue;} ,则显示blue

5、

.min-screen{
background-color: green;
}
#test{
background: blue;
}
.min-screen:hover{
background:pink ;
}
当鼠标移动到div上的时候并不会显示 pink(因为id比class优先级更高),当改为#test:hover{background:pink ;} 时候则会显示pink

还有很多组合,和一些其它情况,在这里我把一些常用的列举出来,感兴趣的可以自己组合选择器再研究

div{
width:200px;
height:200px;
background-color: red;
}
.min-screen{
background-color: green;
}
#test{
background: blue;
}

div[data-index='tt']{
background:yellow;
}
div:hover{
background:pink ;
}
div:nth-child(1){
background:palegreen;
}
div:last-child{
background:#f0ad4e;
}
body div{
background:black;
}
*{
background:violet;
}
p:nth-of-type(1){
color:red;
}

总结:
1、优先级:important>行内style>id>结构性伪类(eg :nth-child() :nth-of-type())>属性>类>标签>通用
2、伪类:hover它的优先级还和最前面的关键字有关(会先比较关键字优先级),上面第五点有详细说明
3、精确匹配优先级更高,上面第二点有说明
4、important凌驾于一切之上(尽量少使用),当两个选择器都存在它时,则比较选择第下个优先级高的,上面第一点有说明
5、动态编写css,在.css文件中所有的属性都无法传参编写,可在html 的head中建立style标签,通过js动态编写style中的样式

回答(3):

这个东西没有顺序,它的顺序在于你对它放置的位置

#s {color:#fff;}
.r {color:#000;}

放置的位置越往下,权重越高
下边的这个颜色就会是黑色

你好

回答(4):

1、最高级的是标签选择器(就是你说的标记选择器)
2、其次是ID选择器
3、然后是类选择器
注意,如果CSS语句后面有 !important,代表最高优先级