掌握CSS匹配原理,编写完美CSS代码
创始人
2024-07-13 13:51:29
0

本节和大家重点讨论一下CSS查找匹配原理和简洁高效的CSS代码的编写,所谓高效的CSS就是让浏览器在查找style匹配的元素的时候尽量进行少的查找,相信本文介绍一定会让你有所收获的。

了解CSS的查找匹配原理,写更简洁高效的CSS代码

使用了这么多年的CSS,现在才明白CSS的真正匹配原理,不知道你是否也跟我一样?看1个简单的CSS:

 

  1. DIV#divBoxpspan.red{color:red;}  
  2.  

按习惯我们对这个CSS的理解是,浏览器先查找id为divBox的DIV元素,当找到后,再找其下的所有p元素,然后再查找所有span元素,当发现有span的class为red的时候,就应用该style。多么简单易懂的原理,可是这个理解却是完完全全相反、错误的。

CSS匹配原理:

浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如之前说的DIV#divBoxpspan.red{color:red;},浏览器的查找顺序如下:

先查找html中所有class='red'的span元素,找到后,再查找其父辈元素中是否有p元素,再判断p的父元素中是否有id为divBox的div元素,如果都存在则CSS匹配上。

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