浏览器的重绘、重排

  1. 如何提升页面渲染性能?
  2. 那些行为会引起重绘/重排?
  3. 如何减少页面的重绘/重排?
  • 浏览器渲染进程,分为四个部分,解析html(dom,cssom合成render数),layout进行布局确定大小和尺寸,paint节点绘制为确定的像素指令在各个层的位置,composite将所有层按照一定顺序绘制到一个层中,并绘制到屏幕上。
  • 提升性能的方向为较少其中的layout和paint,即减少页面的重绘重排过程。
  • 引起重绘重排的操作:
  • 重绘: 外观变化时(color,opacity)
  • 重排: 布局结果或者节点内容变化时,height position float display等,盒子的尺寸,定位,元素之间的关系,或者获取布局信息时发生重排:offsetTop getComputedStyle等时
  • 优化方法
  • 对dom进行批量的样式操作,不逐一操作
  • 可以先改变position为fixed等,脱离文档流后再操作dom
  • 使用transform: translateZ(0) 或者 will-change 将渲染层提升为合成层,开启GPU加速,提升渲染速度
  • 使用变量对布局信息进行缓存(clientTop),避免频繁读取布局触发重排重绘
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值