CSS优先级计算的底层规则

这次给大家带来CSS优先级计算的底层规则,CSS优先级计算底层规则的注意事项有哪些,下面就是实战案例,一起来看一下。

最近在学习CSS优先级计算的规则这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。

CSS的权重

一、CSS的引入方式  

1.在节点元素上,使用style属性  

2.通过link引入外部文件  

3.通过style标签在页面内引入

三种引入方式的区别

index.html文件

                            Document                            body {                background: red;            }                        

body.css文件

    body {        background: green;    }

1.第一种方式相对后面两种优先级高,与引入顺序无关 无论link和style标签放在head内,还是放在body内,或者放在html标签结尾,页面都会呈现yellow

2.第二种和第三种为平级引入,后引入的样式覆盖之前的引入样式 去掉body上的style标签  

调整link和style标签的先后顺序。link在前,style标签在后,页面呈现red,相反,页面会呈现green

二、获取节点的方式  

1.id  

2.class  

3.标签  

4.属性

id

在一个页面中id值应该是唯一,但是,当出现多个相同id时,样式对所有id节点是有效的,使用方式:#后面跟节点id值

  

第一个段落

第二个段落

#id_p {  color: red;}

结果显示,两个段落中的文字都呈现red  

1.id相对class和标签具有更高的权重,当id和class、标签同时对一个节点设置样式时,id的权重为最高  

2.通过link和style标签对同一个id设置样式时,后引入的样式覆盖之前的样式

class

使用class可以对多个节点同时设置样式,并且可以叠加class使用。使用方式.后面跟节点单个class名

  

第一个段落

第二个段落

.class-p {  color: red;}.class-p-2 {  color: green;}

此时,第一个段落呈现red,第二个段落呈现green

调整html

  

第一个段落

第二个段落

调整class-p和class-p-2的位置后,页面呈现效果不变。说明:class样式的渲染和class的使用顺序无关,与class样式设置的先后顺序有关,同权重的class样式,在样式设置中,靠后的样式设置覆盖之前的样式设置

属性

通过节点上的属性也可以得到要进行样式设置的节点

  

第一个段落

第二个段落

[title] {  color: red;}

第二个段落有title属性,所以第二个段落呈现red

标签

通过标签名获取节点进行样式设置

  

第一个段落

第二个段落

p {  color: red;}

页面中所有p标签节点呈现red

混合

以上四种方式可以混合使用,对相应的节点进行样式设置。结合方式包括层级嵌套、样式叠加、节点关联等。最终以权重高者为呈现效果。

三、样式权重

以上四种方式,针对单个而言,id最高,class和属性同级(后面的样式覆盖之前的样式),标签最低。

当四种方式混合使用时,则以权重的结果为准。对同一结点存在的id、class、属性和标签样式进行排序,排位第一者为最终呈现效果。例如:对于节点p存在多种类型的样式设置,首先挑选所有带id的样式,包括嵌套样式。相同id下,对另一类型样式进行排序

  

第一个段落

.body #id_p {  color: red;}#id_p {  color: green}

虽然两种样式设置都有id,并且green效果在red之后被设置,但是通过排序可以得到相同#id_p下,前一个存在.body,所以最终呈现效果为red

存在class、属性和标签的样式时,依次排序,同类型或同权重(class和属性同权重)的样式,靠后的样式覆盖之前的样式(以类型为准,不以名称为准),最终排位第一者为最终呈现效果。

注意:  

1.嵌套、叠加、>、 +等方式,不会影响最终效果。  

2.:nth-child、:first-child、:last-child等伪类高于class和属性

四、!important

!important为样式中的特例,它的权重为最高,高于id、class、属性、标签以及style属性


.body {  background: green !important;}

页面呈现效果为green。但是当对样式设置进行排序时,仍然是同类型样式下,以另一类型权重高者为最终效果。例如

body.body {  background: blue !important;}.body {  background: green !important;}

相同class及!important下,前一种样式设置存在body标签,后一种则没有,所以最终效果呈现blue

说明

1.尽量避免使用!important。因为!important权重最高,会对节点的该属性做强制性设置,在使用时要慎重

2.使用场景

引入插件时,对插件中的样式进行强覆盖。当引入插件时,在不想修改插件中的样式代码情况下,可通过!important对插件内的样式属性进行强制复写

对行内样式进行强覆盖。对于自动生成或者动态引入的的带有行内样式html结构时,可以通过!important对行内样式进行强制复写

1.变通

!important在很多时候是不建议使用的,在stylelint中有一项规则即禁止使用!important。有一种变通的方式,可以在多数情况下实现类似!important`的效果

html

一段文本

css .body .p .span { color: red; } .span.span.span.span.span {/** 自身样式叠加 **/ color: green; }

在不考虑行内样式和id的情况下,对自身样式进行重复叠加多次使用,可以增加class权重,对样式进行复写。

使用前提:  

1.没有行内样式style属性  

2.没有id样式  

3.自身样式叠加次数多余嵌套个数

好处:不用考虑DOM层级关系,减少层级嵌套

五、总结

综合以上说明,权重的计算基本遵从以下规则:  

1.按类型比对,类型权重高者显示;  

2.同类型,按数量比对,多者显示;  

3.同数量,按先后顺序比对,后者显示

嵌套的使用建议

样式嵌套使用,除了增加权重外,也体现了DOM的某种结构关系。但嵌套并不是在任何情况下都需要的。

嵌套多用于块内独有的样式设置。某种样式仅在某个块内有效,可使用嵌套。

多个页面同时开发时,为避免合并后样式被覆盖,可使用嵌套。

嵌套的使用并不是越多越好。嵌套越多,权重越大,但同时对页面的性能消耗也越大。建议使用继承和样式叠加。  

相信看了本文案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!

推荐阅读:

立即学习“前端免费学习笔记(深入)”;

用CSS3实现弹幕效果

你不知道的冷门CSS属性

css的绝对定位怎么兼容所有的分辨率

以上就是CSS优先级计算的底层规则的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1609467.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 00:47:51
下一篇 2025年12月24日 00:48:15

相关推荐

  • css3的旋转木马

    这次给大家带来css3的旋转木马,实现css3旋转木马的注意事项有哪些,下面就是实战案例,一起来看一下。 1、perspective perspective属性包括两个属性:none和具有单位的长度值。 其中perspective属性的默认值为none,表示无限的角度来看3D物体,但看上去是平的。另…

    好文分享 2025年12月24日
    000
  • CSS之巧用渐变

    这次给大家带来CSS之巧用渐变,CSS使用渐变注意事项有哪些,下面就是实战案例,一起来看一下。 前言 本文主要分享了关于CSS3中linear-gradient和radial-gradient的相关知识,带给大家使用渐变的另一个角度。感兴趣的朋友们下面来一起看看详细的介绍:  一、线性渐变 这里需要…

    2025年12月24日 好文分享
    000
  • CSS3的filter(滤镜)属性详解

    这次给大家带来CSS3的filter(滤镜)属性详解,使用CSS3的filter(滤镜)属性的注意事项有哪些,下面就是实战案例,一起来看一下。 最近在做网站的过程中发现了一个非常强大的CSS3属性,就是filter(滤镜)属性,喜欢p图的朋友看名字都应该知道这是什么神器了吧。当然,这个属性的效果肯定…

    2025年12月24日 好文分享
    000
  • 浅析css的display属性

    本文主要和大家浅析css的display属性,需要的朋友可以参考下,希望能帮助到大家。下面跟随小编一起来看一下吧。 display有哪些比较常用的值呢? 在通常的项目开发中比较容易被使用的值主要有: none(元素不会被显示);block(元素将显示为块级元素,元素前后会带有换行符);inline(…

    好文分享 2025年12月24日
    000
  • 详解css加载会造成阻塞吗_CSS教程_CSS_网页制作

    这次给大家带来详解css加载会造成阻塞吗,css加载造成阻塞的注意事项有哪些,下面就是实战案例,一起来看一下。 终于考试完了,今天突然想起来前阵子找实习的时候,今日头条面试官问我,js执行会阻塞DOM树的解析和渲染,那么css加载会阻塞DOM树的解析和渲染吗?所以,接下来我就来对css加载对DOM树…

    2025年12月24日 好文分享
    000
  • css做出打点效果

    这次给大家带来css做出打点效果,css做出打点效果的注意事项有哪些,下面就是实战案例,一起来看一下。 代码如下: 进行中…dot { display:inline-block; width:3ch; text-indent:-1ch; vertical-align:bottom; overfl…

    好文分享 2025年12月24日
    000
  • css的绝对定位怎么兼容所有的分辨率

    这次给大家带来css的绝对定位怎么兼容所有的分辨率,css绝对定位兼容所有分辨率的注意事项有哪些,下面就是实战案例,一起来看一下。 有时候我们在写页面中,会发现绝对定位的父级元素已经相对定位了,但是在不同分辨率的电脑下,绝对定位还是会错乱,似乎父级的相对定位并没有起了作用。 首先要明白如下几个原理:…

    2025年12月24日
    000
  • css中属性值继承如何使用

    这次给大家带来css中属性值继承如何使用,使用css中属性值继承的注意事项有哪些,下面就是实战案例,一起来看一下。 继承:html元素可以从父元素那里继承一部分css属性,即使当前元素没有定义该属性。 1.css可以和不可以继承的属性 不可继承的:display、margin、border、padd…

    好文分享 2025年12月24日
    000
  • CSS定制文本省略的方法

    这次给大家带来CSS定制文本省略的方法,CSS定制文本省略的注意事项有哪些,下面就是实战案例,一起来看一下。 WeTest导读 拿到设计MM的设计稿,Oh NO,点点点后面又双叒叕加内容了,弹丸之地,劳心费神啊!!可怜我们UI开发GG每次苦口婆心说,微臣不是不做,是办不到啊!很是愧疚。而现在,自从用…

    2025年12月24日 好文分享
    000
  • 你不知道的冷门CSS属性

    你不知道的冷门CSS属性这次给大家带来,使用冷门CSS属性的注意事项有哪些,下面就是实战案例,一起来看一下。 每年都有新的CSS属性被标准化,并在主流浏览器中可用。 它们旨在使Web开发人员的工作变得轻松,创造出新颖美丽的网站。 在这篇文章中,我将介绍5个相对较新的CSS属性,你可能从来没有听说过,…

    2025年12月24日
    000
  • 用CSS3实现弹幕效果

    这次给大家带来用CSS3实现弹幕效果,用CSS3实现弹幕效果的注意事项有哪些,下面就是实战案例,一起来看一下。 最近需要项目需要实现弹幕,网上参考了各种方法,最后觉得transform+transition实现的效果在移动设备上性能最好,在iphone6和红米4上测试,看不到卡顿的感觉。用jquer…

    好文分享 2025年12月24日
    000
  • 用CSS实现页面的尖角、小三角、不同方向尖角

    这次给大家带来用CSS实现页面的尖角、小三角、不同方向尖角,用CSS实现页面的尖角、小三角、不同方向尖角的注意事项有哪些,下面就是实战案例,一起来看一下。 效果图: 方法一的效果图: 方法二的效果图: 方法三的效果图: 方法1:因为有背景,所有实现起来比较方便,尖角的内部同个颜色就可以不用考虑遮挡问…

    2025年12月24日 好文分享
    000
  • css3实现wifi信号形状

    这次给大家带来css3实现wifi信号形状,css3实现wifi信号形状的注意事项有哪些,下面就是实战案例,一起来看一下。 整理文档,搜刮出一个css3实现wifi信号逐渐增强效果实例的代码,稍微整理精简一下做下分享。 效果图 下面是实现代码: wifi信号 *{ margin: 0; paddin…

    2025年12月24日
    000
  • 怎样用CSS3来代替JS实现交互效果

    这次给大家带来怎样用CSS3来代替JS实现交互效果,用CSS3来代替JS实现交互效果的注意事项有哪些,下面就是实战案例,一起来看一下。 【CSS3和JS】 对于CSS了解的同学都知道,CSS的实现是最底层的,在实现方式和性能上都不是,JS这种提供接口的脚本可比的;从CSS3的动画和JS动画对比角度来…

    2025年12月24日
    000
  • css清除浮动float的兼容性方法

    这次给大家带来css清除浮动float的兼容性方法,css清除浮动float兼容性方法的注意事项有哪些,下面就是实战案例,一起来看一下。 在清除浮动前我们要了解两个重要的定义: 浮动的定义:使元素脱离文档流,按照指定方向发生移动,遇到父级边界或者相邻的浮动元素停了下来。 高度塌陷:浮动元素父元素高度…

    好文分享 2025年12月24日
    000
  • 用css3做出气球图片样式

    这次给大家带来用css3做出气球图片样式,用css3做出气球图片样式的注意事项有哪些,下面就是实战案例,一起来看一下。 气球效果图: html: css: .balloon{ width: 160px; height: 160px; background: #faf9f9; /*css3 圆角属性*…

    2025年12月24日
    000
  • css实现操作table列

    这次给大家带来css实现操作table列,css实现操作table列的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 最近在做的后台管理系统要处理大量的表格,因为原项目是采用的for循环加拼接字符串的方式实现;导致js代码一大堆;各种单引号和双引号的嵌套;让人头疼;遂引入vue.js;用v-…

    好文分享 2025年12月24日
    000
  • CSS图片下有间隙如何处理

    这次给大家带来CSS图片下有间隙如何处理,处理CSS图片下有间隙的注意事项有哪些,下面就是实战案例,一起来看一下。 在进行页面的p+CSS排版时,遇到IE6(当然有时Firefox下也会偶遇)浏览器中的图片元素img下出现多余空白的问题绝对是常见的对於 该问题的解决方法也是「见机行事」,根据原因的不…

    好文分享 2025年12月24日
    000
  • CSS鼠标悬浮无限生成下级页面

    这次给大家带来CSS鼠标悬浮无限生成下级页面,CSS鼠标悬浮无限生成下级页面的注意事项有哪些,下面就是实战案例,一起来看一下。 废话不多说了,直接大家贴代码了,具体代码如下所示; *{ margin: 0; padding: 0; } ul,li{ list-style: none; } .ui-s…

    2025年12月24日
    000
  • CSS怎样做出梯形的标签页

    这次给大家带来CSS怎样做出梯形的标签页,CSS做出梯形标签页的注意事项有哪些,下面就是实战案例,一起来看一下。 在web设计中,梯形标签页是很常见的一种形式,但是梯形又是一种很难实现的样式,很多开发者会直接用梯形背景图片来生成效果,但是采用背景图片的方式产生了额外的http请求,并不是一种非常理想…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信