本篇内容介绍了“CSS元素选择器是如何运作的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在前端工程师的日常工作中,使用 CSS 元素选择器是稀松平常的事;无论你是编写一般的 CSS 还是需要经过编译的 SASS,SCSS,LESS等,最终都被编译成一行一行的 CSS 样式属性,最终交给浏览器解析并套用。但是你想过没有这是如何实现的呢?浏览器渲染我们先看一下浏览器的渲染步骤:CSS 在被浏览器加载后,会被解析成 CSSOM 树,并尝试与 Dom 叠加成渲染树,随后进行计算位置、渲染等步骤。这样看来,CSS 属性套用的关键就在于如何从 CSS 转化成 CSSOM 树,以及怎么把 CSSOM 套用到 DOM 上去。CSSOM树当我们写下一组 CSS 样式时,例如:浏览器在解析它时,你可能会认为 CSS 会按照由左到右的依序找出#id>.class>h5>p,最后套用,但实际上浏览器解析 CSS 的顺序是由右到左的 p>h5>.class>#id。很违背直觉对吧?但如果考虑到性能问题,从右到左的解析会比从左到右强很多。假设这有这样的 HTML:以及这边五条 CSS 样式规则:让我们模拟一下,如果把 CSS 从左到右解析,将会生成类似这样的 CSSOM 树:通过#div1 .c .d.f .c .d.c .d以此类推,每个 DOM 树上的元素,都必须便利所有的样式规则,才可以取得个别的样式,这样会造成大量冗余的计算,进而严重影响性能。反过来,如果将前面的 CSS 由右到左进行解析,CSSOM 树则可能会如下:和前面的例子一样,从从右到左的解析顺序能够将所有共享的规则路径收拢在一起,当浏览器进行属性比对时,就不用再便利整个 CSSOM 树,大大的减少了无效的比对计算。也可以换个方式思考:在 HTML 的结构中,一个元素可以有无数个子元素,但只能有一个父元素,由子找父(由下往上)搜寻绝对是比较快的。1. 套用样式将 CSSOM 树解析出来之后就能够和 DOM 结合了吗?如果真的有这么简单就太好了。除了开发者定义好的 CSS 档外,还有几个地方可能会定义样式规则,影响画面的渲染:HTML 的 inline style 设置浏览器预设值(就是 CSS reset/normalize 要覆盖掉的东西)浏览器的使用者偏好设定浏览器负责处理 CSS 的部分,会吧前面所有的东西以及 CSS 文件定义的样式规则分别整理成单独的样式规则组(CSS 规则集),内容记载了样式规则、目标属性等信息。2. 目标属性为了提升后面的计算效率,浏览器的 CSS 处理内核会按照样式规则组中个别规则的目标属性将其分组存放;一共分为以下四组idRulesclassRulestagNameRulesuniversalRules这样在取用时,可以依据目标元素是否存在这个属性,快速筛出可能会套用的样式。套用规则最后是套用规则。浏览器会遵循以下顺序和样式规则权重套用所有的样式规则:浏览器的预设值浏览器的使用者偏好设定开发者定义的 CSSinline style加上 !important 的样式属性你可能会好奇:为什么 inline style 和开发者定义的 CSS 会被另外处理?我们可以回顾一下浏览器渲染的步骤,由于 inline style 存在于 DOM 元素中,只能在 CSS 套用到 DOM 上时才会接触到,事前无法将两者结合。CSS 效率实际上浏览器在这里已经完成了优化机制;浏览器会自动将状态一致的元素做样式快照。状态一致就是要满足以下几个条件:没有设定 IDtag 及 class 必须完全一致没有设定 style 属性样式规则中不能使用各种同级选择器(例如:〜,+,:first-child 等)由于上面的条件,以及前面讨论到的 CSS 运算过程,编写 CSS 时也有几个地方可以稍微留心一下:由于样式规则的目标属性会分组存放,id 选择器效率非常高,所以是不能与其他条件混用的。不要写过深的 CSS 样式规则能不用 inline style 就不要用,除了难以维护外,由于是存在于 DOM 树上,无法预先与其他样式合并计算,所以效率也会大打折扣如果能够注意到这类典型的小细节,CSS 效率自然也可以大幅提升。“CSS元素选择器是如何运作的”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注云技术网站,小编将为大家输出更多高质量的实用文章!免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主免费云主机、域名,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@byun.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
相关推荐: css如何使用display:table和display:table-cell实现图片水平垂直居中
这篇文章给大家分享的是有关css如何使用display:table和display:table-cell实现图片水平垂直居中的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。display:table和display:table-cel…