CSS选择器-优先级-性能

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

                                             p:nth-of-type(1)  匹配的是任何元素的所有子元素的第一个p

<div>
    <p>3</p>
    <span>4</span>
    <p>5</p>
    <span>6</span>
</div>
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解析 ),感谢博主!!!


下面着重介绍选择器优先级,我们都是站在巨人的肩膀上做了一些自己的见解,帮助大家更好的理解它

之前看了网上的其它一些博客,感觉讲得都很繁琐,计算什么权重,感觉都挺官方的,我在这里介绍一些常见的、通俗易懂的方法,

<div class="min-screen" id="test" data-index="tt"></div>

优先级 行内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中的样式

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSS选择器是用于选择HTML文档中的元素的模式。常见的CSS选择器包括: 1. 元素选择器:通过元素的标签名选择元素,如`p`选择所有的段落元素。 2. 类选择器:通过元素的class属性选择元素,使用`.`符号,如`.container`选择class为"container"的元素。 3. ID选择器:通过元素的id属性选择元素,使用`#`符号,如`#header`选择id为"header"的元素。 4. 属性选择器:通过元素的属性选择元素,如`[type="text"]`选择所有type属性值为"text"的元素。 5. 后代选择器:通过元素的后代关系选择元素,使用空格分隔,如`.container p`选择class为"container"的元素内部的所有段落元素。 6. 子元素选择器:通过元素的直接子元素关系选择元素,使用`>`符号,如`.container > p`选择class为"container"的元素下的直接子元素中的所有段落元素。 7. 相邻兄弟选择器:通过元素的相邻兄弟关系选择元素,使用`+`符号,如`h2 + p`选择紧接在h2元素后面的p元素。 8. 伪类选择器:通过元素的状态或位置选择元素,如`:hover`选择鼠标悬停的元素。 CSS选择器优先级表示了当多个选择器同时应用于同一个元素时,哪个选择器的样式规则会被应用。通常,优先级的计算规则如下: 1. ID选择器优先级最高,为100。 2. 类选择器、属性选择器和伪类选择器优先级为10。 3. 元素选择器和伪元素选择器优先级为1。 4. 通配符选择器和继承的样式没有优先级,其优先级为0。 如果多个选择器具有相同的优先级,则后面出现的选择器会覆盖前面出现的选择器。如果多个选择器具有不同的优先级,则优先级高的选择器的样式规则会被应用。 需要注意的是,使用`!important`声明可以提升样式规则的优先级,但是过度使用会导致样式难以维护和调试,应尽量避免滥用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值