zoukankan      html  css  js  c++  java
  • web前端优化之reflow(减少页面的回流)

    1、什么是reflow?

    reflow(回流)是指浏览器为了重新渲染部分或者全部的文档,重新计算文档中的元素的位置和几何构造的过程。

    因为回流可能导致整个Dom树的重新构造,所以是性能的一大杀手。

    以下操作会引起回流:

    ① 改变窗口大小

    ② font-size大小改变

    ③ 增加或者移除样式表

    ④ 内容变化(input中输入文字会导致)

    ⑤ 激活CSS伪类(:hover)

    ⑥ 操作class属性,新增或者减少

    ⑦ js操作dom

    ⑧ offset相关属性计算

    ⑨ 设置style的值

    ......

    reflow与repaint是减缓js的几大主要原因,尤其是reflow更是性能杀手,所以我们应该想法避免。

    <style type="text/css">
         .changeStyle {  100px; height: 100px; }
    </style>
    <script type="text/javascript">
         $(document).ready(function () {
             var el = $('id');
             //1
             el.css('width', '100px');
             el.css('height', '100px');
             //2
             el.css({ 'width': '100px;', 'height': '100px;' });
             //3 
             el.addClass('changeStyle');
     
         });
    </script>

    推荐第三种,避免第一种

    以上几种做法,我这里弱弱的推荐第三种,避免第一种。

    ② 具有动画效果请使用absolute

    因为absolute元素的改变对其它元素的回流影响不大,所以我们的动画效果的元素还是将他搞成absolute吧。

    ③ 避免使用表格布局(记住只是布局哦,我们数据还是应该用表格的)

    ④ 请绝对不要使用CSS表达式,性能杀手啊,特别是IE

    ⑤ 在最末改变元素

    因为回流是自上而下的,所以下不及上,我们在最后面修改信息对全局影响越少。

    ⑥ 动画移动时候,要控制

    比如我们拖动元素时候,我是在他x或者y坐标改变5px才操作,这样虽说降低了平滑度,但是对性能有提高。

  • 相关阅读:
    高可用开源方案 Keepalived VS Heartbeat对比
    linux服务器之LVS、Nginx和HAProxy负载均衡器对比总结
    lvs + keepalived + httpd 高可用集群(转)
    OSPF 原理
    网络层 IP 协议首部格式与其配套使用的四个协议(ARP,RARP,ICMP,IGMP)
    WiresShark 一站式学习
    WiresShark 使用方法
    缺陷管理工具JIRA破解版及其安装方法
    Android开发之旅:环境搭建及HelloWorld
    五款超实用的开源 SVG 工具
  • 原文地址:https://www.cnblogs.com/GreenLeaves/p/6509398.html
Copyright © 2011-2022 走看看