常见CSS选择器的权重和优先级
一、常见CSS选择器
【元素选择器】
1、通配选择器:*(匹配所有元素)
a、效率不高,页面上的标签越多,效率越低,所以页面上最好不要出现这个选择器
2、标签选择器:li(匹配标签为li的元素)
a、所有标签都能够当做选择器,比如body、h1、dl、ul、span等等
b、不管这个标签藏的多深,都能够被选择上
c、选择的是所有的,而不是某一个。所以是共性,而不是特性
3、ID选择器:#content(匹配ID属性值等于content的元素)
4、类选择器:.list(匹配class属性包含list的元素)
a、class可以重复,也就是说,同一个页面上可能有多个标签同时属于某一个类
b、同一个标签可以同时携带多个类,多个类用空格隔开,多个样式有冲突的,以css中后出现的为准
c、不要去试图用一个类名,把某个标签的所有样式写完。这个标签要多携带几个类,共同造成这个标签的样式
d、每一个类要尽可能小,有“公共”的概念,能够让更多的标签使用
【关系选择器】
1、后代选择器:#content h3(匹配ID为content的元素内所有的h3元素)
a、空格就表示后代,强调一下:选择的是后代,不一定是儿子
b、当要把某一个部分的所有的什么,进行样式改变,就要想到后代选择器
2、子元素选择器:#content>h3(匹配ID为content的元素子级的h3元素)
3、交集选择器:h3.content(匹配class为content的h3元素)
a、交集选择器没有空格
b、交集选择器可以连续交(一般不要这么写)
c、交集选择器,我们一般都是以标签名开头,比如div.haha 比如p.special
4、并集选择器(分组选择器):h1,h2(匹配所有的h1和h2元素)
5、相邻选择器:h1+h2(匹配 h1 元素之后紧跟的 h2 元素)
6、兄弟选择器:h1~h2(匹配 h1 元素之后所有的 h2 元素)
【属性选择器】
1、a[class]:匹配具有 class 属性值的 a 的元素
2、a[target="_blank"]:匹配 target 属性值等于 _blank 的 a 元素
3、a[href^="https"]:匹配 href 属性值以 https 开头的 a 元素
4、a[href$=".jpg"]:匹配 href 属性值以 .jpg 结尾的 a 元素
5、a[href*="baike"]:匹配 href 属性值包含 baike 的 a 元素
6、a[class~="abc"]:匹配 class 属性值以空格为分隔符,其中有一个等于 abc 的 a 元素
伪类选择器和伪元素选择器使用频率不高,本文暂不说明,详细示例可参考:https://www.haorooms.com/tools/css_selecter/
二、CSS选择器权重和优先级
共分为5个等级 :
第1等:提升指定样式规则的应用优先权,如:color:red !important,权值为10000(不建议使用)
第2等:代表内联样式,如: style="xxx",权值为1000
第3等:代表ID选择器,如:#content,权值为100
第4等:代表类,伪类和属性选择器,如.content,:hover,[attribute],权值为10
第5等:代表元素选择器和伪元素选择器,如div,p,权值为1
通用选择器(*),子选择器(>)和相邻同胞选择器(+)并不在这四个等级中,所以他们的权值都为0
三、CSS选择器权重计算

1、元素被两个css样式选中,选择权重大的样式,如果权重一样,以css中后出现的为准
2、元素没有被css样式选中,要显示继承的样式时,使用就近原则
2、继承的样式权重为0(color、 text-开头的、line-开头的、font-开头的样式都可以继承)
判断一块内容的样式是什么?按照以下步骤:

HTML代码:
<div id="content">
<div id="main-content">
<h2>CSS简介</h2>
<p>CSS是一组格式设置规则,用于控制Web页面的外观。</p>
<div class="paragraph">
<h2 class="first">使用CSS布局的优点</h2>
<p>1、表现和内容相分离 2、提高页面浏览速度 3、易于维护和改版</p>
</div>
</div>
</div>
CSS代码:
/* 100(#main-content) + 10(class="paragraph") + 1(h2) = 111 */
#main-content [class="paragraph"] h2 {
color:yellow;
} /* 100(#main-content) + 1(div) + 10(.paragraph) + 1(h2) = 112 */
#main-content div.paragraph h2 {
color:orange;
} /* 1(body) + 100(#content) + 1(div) + 10([id="main-content"]) + 1(h2) = 113 */
body #content div[id="main-content"] h2 {
color:green;
} /* 1(div) + 100(#main-content) + 1(div) + 10(.paragraph) + 1(h2) + 10(.first) = 123 */
div#main-content div.paragraph h2.first {
color:pink;
} /* 100(#content) + 100(#main-content) + 1(h2) = 201 */
#content #main-content>h2 {
color:blue
} /* 100(#content) + 1(div) + 100(#main-content) + 1(h2) = 202 */
#content div#main-content h2{
color:red;
}
常见CSS选择器的权重和优先级的更多相关文章
- CSS选择器的权重与优先规则?
		
我们做项目的时候,经常遇到样式层叠问题,被其他的样式覆盖,或者写的权重不高没效果,对权重没有具体的分析,做了一个总结. css继承是从一个元素向其后代元素传递属性值所采用的机制.确定应当向一个元素应用 ...
 - css选择器的分类及优先级计算方法总结
		
首先声明一下CSS三大特性—— 继承. 优先级和层叠.继承即子类元素继承父类的样式;优先级是指不同类别样式的权重比较;层叠是说当数量相同时,通过层叠(后者覆盖前者)的样式. css选择符分类 首先来看 ...
 - css选择器万年不变的优先级和权重
		
我们在使用CSS对网页元素定义样式时经常会遇到这种情况:要对一般元素应用一般样式,然后在更特殊的元素上覆盖它们.那么我们怎么样来保证我们所新定义的元素样式能覆盖目标元素上原有的样式呢? 在CSS中,会 ...
 - css选择器有哪些,选择器的权重的优先级
		
选择器类型 1.ID #id 2.class .class 3.标签 p 4.通用 * 5.属性 [type="text"] 6.伪类 :hover 7.伪元素 ::first-l ...
 - CSS选择器的权重与优先规则
		
权重顺序 “important > 内联 > ID > 类 > 标签 | 伪类 | 属性选择 > 伪对象 > 继承 > 通配符”. 原文:http://w ...
 - CSS选择器及其权重
		
#转载请留言联系 1.标签选择器 标签选择器,此种选择器影响范围大,一般用来做一些通用设置,或用在层级选择器中.举例: div{color:red} ...... <div>这是第一个di ...
 - HTML选择器的权重(优先级)
		
选择器的优先级主要用于样式发生冲突的情况下 选择器范围越小,优先级越高 行内样式>id选择器>类选择器>标签选择器>通用选择器 这里涉及一个权重值的问题,权重值越高,优先级越大 ...
 - css选择器的权重
		
权重会叠加!
 - CSS选择器的权重与优先规
		
我们把特殊性分为4个等级,每个等级代表一类选择器,每个等级的值为其所代表的选择器的个数乘以这一等级的权值,最后把所有等级的值相加得出选择器的特殊值. 4个等级的定义如下: 第一等:代表内联样式,如: ...
 
随机推荐
- Nginx是如何处理一个请求
			
首先,nginx在启动时,会解析配置文件,得到需要监听的端口与ip地址,然后在nginx的master进程里面,先初始化好这个监控的socket(创建socket,设置addrreuse等选项,绑定到 ...
 - [前端开发]Vue mixin
			
两个非常相似的组件,他们的基本功能是一样的,但他们之间又存在着足够的差异性,此时的你就像是来到了一个分岔路口:我是把它拆分成两个不同的组件呢?还是保留为一个组件,然后通过props传值来创造差异性从而 ...
 - 简说Spring中的资源加载
			
声明: 本文若有 任何纰漏.错误,请不吝指正!谢谢! 问题描述 遇到一个关于资源加载的问题,因此简单的记录一下,对Spring资源加载也做一个记录. 问题起因是使用了@PropertySource来进 ...
 - 阿里P9精心编写高并发设计手册,来看大厂是如何进行系统设计
			
在看这篇文章的应该都是IT圈的朋友吧,不知道你们有没有考虑过这样几件事: 淘宝双11的剁手狂欢为什么天猫没崩掉? 为什么滴滴打车高峰如何滴滴依旧可以平稳运行? 为什么疫情期间,钉钉能支撑那么多人同时上 ...
 - Java——参数传递
			
写这篇文章时,其实还是不理解Java中的参数传递只有传值没有传址(传引用).这里引用知乎上大神的讲解来记录一下. 一.基本类型和引用类型 int num = 10; String str = &quo ...
 - bootstrap table  Showing 1 to 5 of 5 rows 页码显示英文
			
注意导包先后顺序bootstrap-table-zh-CN.js链接:https://cdn.bootcdn.net/ajax/libs/bootstrap-table/1.16.0/locale/b ...
 - Burpsuite代理socks流量
			
一 设置sock代理 二 设置浏览器代理 三 设置burpsuite代理 四 浏览器访问验证 总结:增加取证难度,隐藏你自己ip,别光着屁股跑了O-O!
 - web-信息泄露基础知识总结(持续更新)
			
web-信息泄露 1.git泄露 Git是一个开源的分布式版本控制系统,在执行git init初始化目录的时候,会在当前目录下自动创建一个.git目录,用来记录代码的变更记录等.发布代码的时候,如果没 ...
 - Rocket - devices - CanHaveBuiltInDevices
			
https://mp.weixin.qq.com/s/C9iktVr4hnQ8lM0CiWtedQ 简单介绍CanHaveBuiltInDevices的实现. 1. HasBuiltInDeviceP ...
 - Rocket - debug - TLDebugModuleInnerAsync
			
https://mp.weixin.qq.com/s/Xf4VFTHIDFh1NHmfwlTX3w 简单介绍TLDebugModuleInnerAsync的实现. 1. dmInner dmInner ...