• 如何提升CSS性能


    大家都知道,对于网站来说,性能至关重要,CSS作为页面渲染和内容展现的重要环节,影响着用户对整个网站的第一体验。因此,与其相关的性能优化是不容忽视的。对于性能优化我们常常在项目完成时才去考虑,经常在项目的末期,性能问题才会暴露出来,此时才进行一些相关的性能优化。其实,如果我们从一开始编码,就注意一些细节问题,后面的工作量会小很多,下面我们来看看在书写CSS时,我们可以注意哪些细节,从而来提升CSS处理性能。

    先来看看这段代码:

    <style>
        .red{ color: red; }
        .blue{ color: blue; }
    </style> 
    <div class="red blue">这是什么颜色</div> 
    <div class="blue red">这是什么颜色</div>

    你觉得这两块内容文字各是什么颜色呢?答案是:都是蓝色!!!

    回到主题:如何提升 CSS 性能?

    一、减少后代选择器的使用

    先来了解一下后代选择器,看如下代码:

    1 div p {
    2     color: red; 
    3     font-size: 14px; 
    4 }

    样式选择器中间的空格是什么?它的名字是 —— 后代选择器。如果项目很大,后代选择器非常多,这时候就很耗性能。所以不建议使用没有意义的后代选择器,如:

    1 .div p {}

    后代选择器为什么会更消耗性能呢?因为浏览器首先会找到所有 p 标签,然后再向上查找包含 class 为 div 标签。这样一来如果代码中有很多 p 标签,无疑是会做很多重复工作的。

    二、减少使用HTML标签来定义CSS的方式,换成使用具体的class

    浏览器会从右到左解析CSS选择器,如下代码:

    1 .box div p a {}

    浏览器会对上面的例子做如下的步骤处理:

    1、首先找到页面所有的 <a> 元素

    2、然后向上找到被 <p> 元素包裹的 <a> 元素

    3、再向上查找到一直到 .box 的元素

    从上面的步骤我们可以看出,越靠右的选择器越具有唯一性,浏览器解析 CSS 属性的效率就越高。所以一定换成使用具体的 class 编写 CSS 代码,可以有效的提升性能。

    三、避免reflow、repaint风险

    我们知道修改某些 CSS 属性会导致整个页面布局的重绘( repaint )/重排( reflow )。重绘的速度远快于重排,所以避免重排更重要。重排会导致浏览器重新计算整个文档,重新构建渲染树,这一过程会降低浏览器的渲染速度。如下所示,有很多操作会触发重排,我们应该避免频繁触发这些操作。

    • 改变font-size和font-family

    •  改变元素的内外边距

    •  通过JS改变CSS类

    •  通过JS获取DOM元素的位置相关属性(如width/height/left等)

    •  CSS伪类激活

    •  滚动滚动条或者改变窗口大小

    值得一提的是,某些CSS属性具有更好的重排性能。如使用Flex时,比使用inline-block和float时重排更快,所以在布局时可以优先考虑Flex。如果大量的元素更改这些属性,那么计算和更新他们的位置/大小需要花费很长的时间。

    四、减少某些消耗性能的CSS属性

    有一些 CSS 属性会比其他属性消耗能多的性能,即浏览器解析这些属性需要花费更多的时间。 如:border-radius、box-shadow、filter、:nth-child等。当然这些属性我们经常使用,有些无法避免。要做出适当的取舍。比如:nth-child,第一个元素你可以换成:first-child,最后一个可以换成:last-child。

    如果感兴趣可以去看看腾讯IMWeb团队写的这篇文章:https://imweb.io/topic/5c2206a7611a25cc7bf1d848

  • 相关阅读:
    sqlserver用windows方式验证登录踩过的坑
    jdk8对象集合转map集合
    监听程序当前无法识别连接描述符中请求的服务解决方案
    Java上传文件至SFTP服务器
    记一次学习kibaba踩过的坑(Windows环境)
    CSRF跨站请求伪造与XSS跨域脚本攻击讨论
    LVS简单搭建(一)
    LVS+keepalived简单搭建(二)
    JZ2440开发板学习 1. 刚接触开发板, 安装驱动
    用STM32CubeMX创建FreeRTOS项目
  • 原文地址:https://www.cnblogs.com/guchengnan/p/14361003.html
Copyright © 2020-2023  润新知