首页 > 其他分享 >CSS中的选择器优先级考虑

CSS中的选择器优先级考虑

时间:2022-11-28 20:09:47浏览次数:67  
标签:span color red 优先级 选择器 CSS


先来看个例子:

css02.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS id选择器</title>
<link rel="stylesheet" type="text/css" href="css02.css">
</head>
<body>
<!--考虑选择器的优先级-->
<p id="pid">Hello CSS
<a href="http://www.baidu.com">百度</a>
<span>Hello HTML5</span>
</p>
<div id="divid">
这是div<p>这是p标签</p>
</div>
</body>
</html>


样式表 css02.css

#pid span{
color: red;
}
#divid{
color:blue;
}

/*p{
color:greenyellow;
}*/

/*
#pid span{
color:greenyellow;
}*/


运行结果在Chrome中显示如下:

CSS中的选择器优先级考虑_css

结果分析:“Hello HTML5"颜色发生了变化——》因为通过设置了 #pid span;div内的内容颜色发生了变化,尽管部分内容通过p标签承载了,p标签内的内容也受到了#divid样式的影响。


后面修改样式为:

#pid span{
color: red;
}
#divid{
color:blue;
}

p{
color:greenyellow;
}

/*
#pid span{
color:greenyellow;
}*/

运行结果在Chrome中显示如下:

CSS中的选择器优先级考虑_优先级_02

结果分析需要 参考: 

​​css知多少(6)——选择器的优先级​​

​​详解CSS选择器、优先级与匹配原理​​

原文如下:

css知多少(6)——选择器的优先级


1. 引言

  上一节《​​css知多少(5)——选择器​​》最后提到,选择器类型过多将导致一些问题,是什么问题呢?咱们直接举例子说明。



CSS中的选择器优先级考虑_css_03



 上图中,css中的两个选择器都是针对<span>的,而且两个设置的颜色不一样,这里的<span>到底听从谁的命令?

  上面还是比较简单的,下面在来一个复杂的:



CSS中的选择器优先级考虑_css_04



 上图中的<li>该显示成什么颜色呢?

2. 特指度

特指度(specificity)。特指度表示一个css选择器表达式的重要程度,可以通过一个公式来计算出一个数值,数越大,越重要。

“I-C-E”计算公式,

  1. I——Id;
  2. C——Class;
  3. E——Element;

遇到一个id就往特指度数值中加100,遇到一个class就往特指度数值中加10,遇到一个element就往特指度数值中加1。

  下面举几个css表达式的特指度计算结果,大家也自己算一算,是不是对:

CSS选择器表达式

特指度计算结果

p

1

p.large

11

P#large

101

div p#large

102

div p#large ul.list

113

div p#large ul.list li

114

!important优先级最高,高于上面一切。* 选择器最低,低于一切。

  好了,你现在可以返回文章一开始提出的两个问题,根据特指度计算公式计算,哪个的计算结果大,浏览器就会以哪个为优先。

3. 简版规则

  如果你嫌上面的计算过于复杂,有一个简版规则。它只有三个规则,这三个规则能覆盖大多数情况,而且比较好记。

  规则一,包含ID的选择器胜过包含Class的选择器,包含Class的选择器胜过包含元素的选择器;例如下图,第一个特指度更高:



CSS中的选择器优先级考虑_CSS选择器的优先级_05



规则二,不同选择器的特指度比较时,不区分加载的顺序(相同选择器在层叠时,后加载的覆盖前加载的),例如下图,虽然后加载,但是特指度低:


CSS中的选择器优先级考虑_选择器_06


规则三,设置的样式高于继承的样式,不用考虑特指度。例如:


CSS中的选择器优先级考虑_选择器_07


  其实,大部分情况下,你通过这个简版的规则,即可判断选择器的优先级。

4. 亲身经历

  wangEditor是我自己做的一个富文本编辑器,当我最开始在博客园上配置demo页面的时候,就遇到了css选择器优先级的问题,现在已经解决。Demo地址:​​javascript:void(0)​​

  对于下来菜单,例如选择字体、字号等,我当时在wangEditor的css中是用Class来设置的,谁知道博客园页面中有一个既有的样式,优先级高于我的:



CSS中的选择器优先级考虑_选择器_08



  导致了我配置的demo中,ul的margin-left还是45px,而我写的css明明已经设置成了0px。原因就是博客园这个css选择器优先级要高于我写的优先级。

  当然,后来我改成了id选择器,就改过了这个问题。

5. 总结

  本节的内容是一个重点,我在许多的面试题中看到过考css优先级的问题。css优先级并不麻烦,只要你掌握了合适的方法来学习,一晚上就入门个差不多,祝君好运。

---------------------------------------------------------------

本系列的目录页面:​​javascript:void(0)​​

-------------------------------------------------------------------------------------------------------------

欢迎关注我的教程:

《​​用grunt搭建自动化的web前端开发环境​​​》《​​从设计到模式​​​》《​​深入理解javascript原型和闭包系列​​》《​​微软petshop4.0源码解读视频​​​》《​​json2.js源码解读视频​​》

​wangEditor,简洁易用的web富文本编辑器​

-------------------------------------------------------------------------------------------------------------






详解CSS选择器、优先级与匹配原理



给一个p标签增加一个类(class),可是执行后该class中的有些属性并没有起作用。通过Firebug查看,发现没有起作用的属性被覆盖了。这个时候突然意识到了CSS选择器的优先级问题,这里就CSS选择器的优先级问题做了一些总结。

51CTO推荐阅读:​​巧妙地使用CSS选择器​

选择器种类

严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而 在标签内写入style=""的方式,应该是CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。而一般人们将上面这几种方式结合在一起,所 以就有了5种或6种选择器了。

三种基本的选择器类型

语法如下:

◆标签名选择器,如:p{},即直接使用HTML标签作为选择器。

◆类选择器,如.polaris{}。

◆ID选择器,如#polaris{}。

注意,ID选择器跟类选择器有很大的不同:一个页面内不能出现相同的ID;再就是ID也是后台开发人员会经常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合十分娴熟之后,这些都不会成为限制。

扩展选择器

◆后代选择器,如.polaris span img{},后代选贼器实际上是使用多个选择器加上中间的空格来找到具体的要控制标签。

◆群组选择器,如div,span,img{},群组选择器实际上是对CSS的一种简化写法,只不过把有相同定义的不同选择器放在一起,省了很多代码。

选择器的优先级别

了解了各种选择器后,还有一个重要的知识点就是CSS选择器的优先级。这也就是为什么polaris会遇到文章开头的问题。举个简单的例子:

  1. <div class="polaris"> 
  2. <span class="beijixing"> 
  3. beijixing  
  4. </span> 
  5. <span> 
  6. polaris  
  7. </span> 
  8. </div> 

如果已经把.polaris下面span内的字体设置成红色:

  1. .polaris span {color:red;} 

这时,如果要改变.beijixing的颜色为蓝色,用下面的命令是不能实现的:

  1. .beijixing {color:blue;} 

出现这种情况就是因为后一个命令的优先级不够,两条相互冲突的样式设置,浏览器只会执行优先级较高的那个。

那么选择器的优先级是怎么规定的呢?

一般而言,选择器越特殊,它的优先级越高。也就是选择器指向的越准确,它的优先级就越高。通常我们用1表示标签名选择器的优先级,用10表示类选择 器的优先级,用100标示ID选择器的优先级。比如上例当中 .polaris span {color:red;}的选择器优先级是 10 + 1 也就是11;而 .polaris 的优先级是10;浏览器自然会显示红色的字。理解了这个道理之后下面的优先级计算自是易如反掌:

  1. div.test1 .span var 优先级 1+10 +10 +1  
  2. span#xxx .songs li 优先级1+100 + 10 + 1  
  3. #xxx li 优先级 100 +1 

对于什么情况下使用什么选择器,用不同选择器的原则是:第一:准确的选到要控制的标签;第二:使用最合理优先级的选择器;第三:HTML和CSS代码尽量简洁美观。通常:

1、最常用的选择器是类选择器。

2、li、td、dd等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器 .xx li/td/dd {} 的方式选择。

3、极少的情况下会用ID选择器,当然很多前端开发人员喜欢header,footer,banner,conntent设置成ID选择器的,因为相同的样式在一个页面里不可能有第二次。

在这里不得不提使用在标签内引入CSS的方式来写CSS,即:

  1. <div style="color:red">polaris</div> 

这时候的优先级是最高的。我们给它的优先级是1000,这种写法不推荐使用,特别是对新手来说。这也完全违背了内容和显示分离的思想。DIV+CSS的优点也不能再有任何体现。

后代选择器的定位原则

在这里介绍一下对于后代选择器,浏览器是如何查找元素的呢?

浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如DIV#divBox p span.red{color:red;},浏览器的查找顺序如下:先查找html中所有class='red'的span元素,找到后,再查找其父辈元 素中是否有p元素,再判断p的父元素中是否有id为divBox的div元素,如果都存在则匹配上。

浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css:

  1. <style> 
  2. DIV#divBox p span.red{color:red;}  
  3. ><style> 
  4. <body> 
  5. <div id="divBox"> 
  6. <p><span>s1</span></p> 
  7. <p><span>s2</span></p> 
  8. <p><span>s3</span></p> 
  9. <p><span class='red'>s4</span></p> 
  10. </div> 
  11. </body> 

如果按从左到右查找,哪会先查找到很多不相关的p和span元素。而如果按从左到右的方式进行查找,则首先就查找到<span class='red'>的元素。firefox称这种查找方式为key selector(关键字查询),所谓的关键字就是样式规则中最后(最右边)的规则,上面的key就是span.red。

简洁、高效的CSS

所谓高效的CSS就是让浏览器在查找style匹配的元素的时候尽量进行少的查找,下面列出一些我们常见的写CSS犯一些低效错误:

◆不要在ID选择器前使用标签名

一般写法:DIV#divBox

更好写法:#divBox

解释: 因为ID选择器是唯一的,加上div反而增加不必要的匹配。

◆不要再class选择器前使用标签名

一般写法:span.red

更好写法:.red

解释:同第一条,但如果你定义了多个.red,而且在不同的元素下是样式不一样,则不能去掉,比如你css文件中定义如下:

  1. p.red{color:red;}  
  2. span.red{color:#ff00ff} 

如果是这样定义的就不要去掉,去掉后就会混淆,不过建议最好不要这样写

◆尽量少使用层级关系

一般写法:#divBox p .red{color:red;}

更好写法:.red{..}

◆使用class代替层级关系

一般写法:#divBox ul li a{display:block;}

更好写法:.block{display:block;}





标签:span,color,red,优先级,选择器,CSS
From: https://blog.51cto.com/u_15894233/5893563

相关文章

  • CSS中的定位——position属性
    CSS定位指的是改变元素在页面中的位置。CSS定位机制:普通流:元素按照其在HTML中的位置顺序决定排布的过程(也就是我不对元素进行定位的默认排布)浮动绝对布局CSS定位包含的属性......
  • CSS布局——定位
        1.定位的基本介绍     2.定位的基本使用3.静态定位          4.相对定位   注意事项:如果left和right都有则......
  • Swift基础之PickerView(时间)选择器
    代码讲解:(后面有额外代码讲解)首页设计UIPickerView的样式设计:leftArray=["花朵","颜色","形状"];              letarray1=["茉莉","玫瑰","郁金香"......
  • 优先级反转那些事儿
    作者:崔晓兵从一个线上问题说起最近在线上遇到了一些[HMDConfigManagerremoteConfigWithAppID:]卡死初步分析观察了下主线程堆栈,用到的锁是读写锁随后又去翻了下持......
  • 常用css属性flex: 1详解
    flex:1实际代表的是三个属性的简写flex-grow是用来增大盒子的,比如,当父盒子的宽度大于子盒子的宽度,父盒子的剩余空间可以利用flex-grow来设置子盒子增大的占比flex-shrin......
  • Vue3+Vite项目中 使用WindiCSS.
    之前工作有了解过根据类名来写元素的样式,一听就发出疑问:这样写项目可读性恐怕不是很好吧。。。  之后来到杭州工作后,开始使用WindiCSS后发现真香!!! 由于近期所写的项......
  • css 样式总结
    #css样式汇总*处理图片5px间距问题1.给父元素设置font-size:02.给img设置display:block3.给img设置vertical-align:bottom4.给......
  • 【Web技术】188-[译] 现代 JavaScript 与 CSS 滚动实现指南
    编者按:本文由sea_ljf翻译并发表于众成翻译平台,原标题“滑向未来(现代JavaScript与CSS滚动实现指南)”一些(网站)滚动的效果是如此令人着迷但你却不知该如何实现,本文将为......
  • Python 爬取单个网页所需要加载的URL地址和CSS、JS文件地址
    直接上代码:脱敏后自用的py采集代码,#!/usr/bin/envpython#-*-coding:utf-8-*-"""@author:Andy@file:xxx.py@time:下午05:50@desc:采集的文章数据进博客"""im......
  • 创建水平滚动的正确方式【CSS 网格布局】
    原文链接​​Creatinghorizontalscrollingcontainerstherightway[CSSGrid]​​--作者​​DannieVinther​​自从奈飞​​Netflix​​成为了家喻户晓的名字以......