iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >CSS元素选择器是如何运作的
  • 720
分享到

CSS元素选择器是如何运作的

2024-04-02 19:04:59 720人浏览 薄情痞子
摘要

本篇内容介绍了“CSS元素选择器是如何运作的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在前端工程师的日

本篇内容介绍了“CSS元素选择器是如何运作的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

前端工程师的日常工作中,使用 CSS 元素选择器是稀松平常的事;无论你是编写一般的 CSS 还是需要经过编译的  SASS,SCSS,LESS等,最终都被编译成一行一行的 CSS 样式属性,最终交给浏览器解析并套用。但是你想过没有这是如何实现的呢?

CSS元素选择器是如何运作的

浏览器渲染

我们先看一下浏览器的渲染步骤:

CSS元素选择器是如何运作的

CSS 在被浏览器加载后,会被解析成 CSSOM 树,并尝试与 Dom 叠加成渲染树,随后进行计算位置、渲染等步骤。这样看来,CSS  属性套用的关键就在于如何从 CSS 转化成 CSSOM 树,以及怎么把 CSSOM 套用到 DOM 上去。

CSSOM树

当我们写下一组 CSS 样式时,例如:

#id .class h5 + p {    ... }

浏览器在解析它时,你可能会认为 CSS 会按照由左到右的依序找出#id>.class>h5>p,最后套用,但实际上浏览器解析 CSS  的顺序是由右到左的 p>h5>.class>#id。

很违背直觉对吧?但如果考虑到性能问题,从右到左的解析会比从左到右强很多。

假设这有这样的 html

<div id="div1">     <div class="a">         <div class="b">             ...         </div>         <div class="c">             <div class="d">                 ...             </div>             <div class="e">                 ...             </div>         </div>     </div>     <div class="f">         <div class="c">             <div class="d">                 ...             </div>         </div>     </div> </div>

以及这边五条 CSS 样式规则:

#div1 .c .d {} .f .c .d {} .a .c .e {} #div1 .f {} .c .d {}

让我们模拟一下,如果把 CSS 从左到右解析,将会生成类似这样的 CSSOM 树:

CSS元素选择器是如何运作的

通过<div class =“ d”>中的 .d 来思考,这样的 CSSOM 树在套用样式时,必须对所有的样式规则进行检查,以确认样式规则是否会影响到  .d,到最后才能确定可能会影响到 .d 的样式规则有这三条:

  • #div1 .c .d

  • .f .c .d

  • .c .d

以此类推,每个 DOM  树上的元素,都必须便利所有的样式规则,才可以取得个别的样式,这样会造成大量冗余的计算,进而严重影响性能。

反过来,如果将前面的 CSS 由右到左进行解析,CSSOM 树则可能会如下:

CSS元素选择器是如何运作的

和前面的例子一样,从<div class =“ d”>中 .d 的角度来看,由于会被样式规则影响到的目标元素,已经全都集中在第一层了,所以就不用再去便利整个 CSSOM  树了,甚至只需要检查 .d 以下的子属性变量是否符合实际 DOM 结构,再将所有符合的样式规则重新取回,便能完成 .d 对元素的样式规则套用。

从右到左的解析顺序能够将所有共享的规则路径收拢在一起,当浏览器进行属性比对时,就不用再便利整个 CSSOM 树,大大的减少了无效的比对计算。

也可以换个方式思考:在 HTML 的结构中,一个元素可以有无数个子元素,但只能有一个父元素,由子找父(由下往上)搜寻绝对是比较快的。

1. 套用样式

将 CSSOM 树解析出来之后就能够和 DOM 结合了吗?如果真的有这么简单就太好了。

除了开发者定义好的 CSS 档外,还有几个地方可能会定义样式规则,影响画面的渲染:

  • HTML 的 inline style 设置

  • 浏览器预设值(就是 CSS reset/nORMalize 要覆盖掉的东西)

  • 浏览器的使用者偏好设定

浏览器负责处理 CSS 的部分,会吧前面所有的东西以及 CSS 文件定义的样式规则分别整理成单独的样式规则组(CSS  规则集),内容记载了样式规则、目标属性等信息。

2. 目标属性

为了提升后面的计算效率,浏览器的 CSS 处理内核会按照样式规则组中个别规则的目标属性将其分组存放;一共分为以下四组

  • idRules

  • classRules

  • tagNameRules

  • universalRules

这样在取用时,可以依据目标元素是否存在这个属性,快速筛出可能会套用的样式。

套用规则

最后是套用规则。浏览器会遵循以下顺序和样式规则权重套用所有的样式规则:

  • 浏览器的预设值

  • 浏览器的使用者偏好设定

  • 开发者定义的 CSS

  • inline style

  • 加上 !important 的样式属性

你可能会好奇:为什么 inline style 和开发者定义的 CSS 会被另外处理?

我们可以回顾一下浏览器渲染的步骤,由于 inline style 存在于 DOM 元素中,只能在 CSS 套用到 DOM  上时才会接触到,事前无法将两者结合。

CSS 效率

实际上浏览器在这里已经完成了优化机制;浏览器会自动将状态一致的元素做样式快照。状态一致就是要满足以下几个条件:

  • 没有设定 ID

  • tag 及 class 必须完全一致

  • 没有设定 style 属性

  • 样式规则中不能使用各种同级选择器(例如:〜,+,:first-child 等)

由于上面的条件,以及前面讨论到的 CSS 运算过程,编写 CSS 时也有几个地方可以稍微留心一下:

  • 由于样式规则的目标属性会分组存放,id 选择器效率非常高,所以是不能与其他条件混用的。

  • 不要写过深的 CSS 样式规则

  • 能不用 inline style 就不要用,除了难以维护外,由于是存在于 DOM 树上,无法预先与其他样式合并计算,所以效率也会大打折扣

如果能够注意到这类典型的小细节,CSS 效率自然也可以大幅提升。

“CSS元素选择器是如何运作的”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: CSS元素选择器是如何运作的

本文链接: https://www.lsjlt.com/news/84430.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • CSS元素选择器是如何运作的
    本篇内容介绍了“CSS元素选择器是如何运作的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在前端工程师的日...
    99+
    2022-10-19
  • css子元素选择器的作用是什么
    这篇文章主要介绍“css子元素选择器的作用是什么”,在日常操作中,相信很多人在css子元素选择器的作用是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css子元素选择器的作用是什么”的疑惑有所帮助!接下来...
    99+
    2023-06-20
  • css如何使用元素选择器
    这篇文章主要为大家展示了“css如何使用元素选择器”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何使用元素选择器”这篇文章吧。元素选择器标记选择器是指用...
    99+
    2022-10-19
  • CSS元素选择器如何使用
    这篇文章主要介绍“CSS元素选择器如何使用”,在日常操作中,相信很多人在CSS元素选择器如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS元素选择器如何使用”的疑惑...
    99+
    2022-10-19
  • css如何选择子元素
    这篇文章给大家分享的是有关css如何选择子元素的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 选择子元素 如果您不希望选择任意的后代元素,而是希望缩小范围,只选择某个元素的子...
    99+
    2022-10-19
  • css选择器如何选择倒数第几个元素
    小编给大家分享一下css选择器如何选择倒数第几个元素,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 在css中,可以利用“:nth-last-child()”选...
    99+
    2022-10-19
  • css之伪元素选择器如何使用
    这篇文章主要介绍“css之伪元素选择器如何使用”,在日常操作中,相信很多人在css之伪元素选择器如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css之伪元素选择器如何...
    99+
    2022-10-19
  • css如何选择所有子元素
    这篇文章将为大家详细讲解有关css如何选择所有子元素,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在css中可以使用子选择器来选择指定元素的所有子元素:1、使用“E1 > E2{}”格式选择指定元素...
    99+
    2023-06-08
  • css如何选择奇偶行元素
    这篇文章主要介绍“css如何选择奇偶行元素”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“css如何选择奇偶行元素”文章能帮助大家解决问题。在css中,可以利用“:nth-child(n)”选择器来进...
    99+
    2023-07-05
  • CSS的子元素选择器用法介绍
    本篇内容介绍了“CSS的子元素选择器用法介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!基础 子元素选择...
    99+
    2022-10-19
  • CSS中子元素选择器的使用介绍
    这篇文章主要讲解了“CSS中子元素选择器的使用介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS中子元素选择器的使用介绍”吧!与后代选择器相比,子元素...
    99+
    2022-10-19
  • CSS伪类或伪元素选择器该如何整理
    这期内容当中小编将会给大家带来有关CSS伪类或伪元素选择器该如何整理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、超链接    ...
    99+
    2022-10-19
  • css如何使用负的nth-child来选择元素
    这篇文章主要介绍了css如何使用负的nth-child来选择元素,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用负的 nth-child 来选择元素使用...
    99+
    2023-06-27
  • css如何选择div下的第几个p元素
    这篇文章主要讲解了“css如何选择div下的第几个p元素”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css如何选择div下的第几个p元素”吧! ...
    99+
    2022-10-19
  • 如何使用:only-of-type伪类选择器选择父元素只有一个同类型元素的CSS样式
    如何使用:only-of-type伪类选择器选择父元素只有一个同类型元素的CSS样式,需要具体代码示例在使用CSS进行页面设计时,我们经常需要根据元素的数量或特定条件来选择并应用不同的样式。其中一个常用的伪类选择器是:only-of-typ...
    99+
    2023-11-20
    CSS 选择器 only-of-type
  • jQuery如何实现元素选择器
    这篇文章主要介绍了jQuery如何实现元素选择器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下<!DOCTYPE ...
    99+
    2022-10-19
  • 如何使用:not伪类选择器选择不符合条件的元素的CSS样式
    如何使用:not伪类选择器选择不符合条件的元素的CSS样式在CSS中,我们经常会使用选择器来选择符合特定条件的元素,然后对它们应用样式。不过有时候,我们需要选择不符合特定条件的元素,并对其应用不同的样式。这时,就可以使用:not伪类选择器。...
    99+
    2023-11-20
    CSS样式 选择器 not伪类
  • CSS如何选择所有子元素添加样式
    这篇文章主要为大家展示了CSS如何选择所有子元素添加样式,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“CSS如何选择所有子元素添加样式”这篇文章吧。方法:以实际项目中less为例:.lk-tool...
    99+
    2023-06-08
  • 使用:first-child伪类选择器选择第一个子元素的CSS样式
    使用:first-child伪类选择器选择第一个子元素的CSS样式CSS中的伪类选择器是一种强大的工具,可以选择并修改特定的元素。其中,:first-child伪类选择器是一种常用的选择器,它可以选择某个元素的第一个子元素,无论这个子元素是...
    99+
    2023-11-20
    first-child (first) 伪类选择器 (pseudo-class) CSS样式 (CSS style)
  • css选择器的作用是什么
    这篇文章主要介绍“css选择器的作用是什么”,在日常操作中,相信很多人在css选择器的作用是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css选择器的作用是什么”的疑惑...
    99+
    2022-10-19
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作