CSS选择符由一些初始化参数组成,这些参数指明了要应用这个CSS规则的页面元素。
做为一个网站的前端开发工程师,应该避免编写一些常见的开销很大的CSS选择符模式,尽可能编写高效的CSS选择符,从而加快页面的渲染速度,缩短页面呈现时间。css
浏览器读取选择器,遵循的原则是从选择器的 右边到左边读取。换句话说,浏览器读取选择器的顺序是由右到左进行的。
浏览器读取选择器的顺序以下:前端
选择器的最后一部分,也就是选择器的最右边部分被称为 关键选择器 (keyselector),它将决定 CSS 选择器的效率。面试
内联样式 > ID 选择器 > 类选择器 = 属性选择器 = 伪类选择器 > 元素(类型)选择器 = 伪元素选择器正则表达式
ID和类名用于关键选择器上效率是最高的,而CSS3的仿伪类和属性选择器,虽然使用方便,但其效率倒是最低的。segmentfault
根据以上「浏览器读取选择器」与「选择器的效率」原则,咱们能够经过避免不恰当的使用,提高 CSS 选择器的性能。数组
浏览器匹配文档中全部的元素后分别向上逐级匹配 class 为 content 的元素,直到文档的根节点。所以其匹配开销是很是大的,因此应避免使用关键选择器是通配选择器的状况。浏览器
后代选择器在CSS中是最昂贵的选择器。贵得要命——尤为是把它和标签或通配符放在一块儿!性能优化
标签后面最好永远不要再增长子选择器性能
属性选择器根据元素的属性是否存在或其属性值进行匹配,以下例规则会把herf属性值等于 ”#index” 的连接元素设置为红色:优化
但其匹配开销是很是大的,浏览器先匹配全部的元素,检查其是否有href属性而且herf属性值等于”#index”, 而后分别向上逐级匹配class为selected的元素,直到文档的根节点。因此应避免使用关键选择器是单规则属性选择器的规则。
CSS3添加了复杂的属性选择器,能够经过类正则表达式的方式对元素的属性值进行匹配。固然这些类型的选择器定是会影响性能的,正则表达式匹配会比基于类别的匹配会慢不少。大部分状况下咱们应尽可能避免使用 *=, |=, ^=, $=, 和 ~=语法的属性选择器。
移除无匹配的样式,有两个好处: