03渲染优化-04复合线程与图层

复合线程(compositor thread) 就是 将页面拆分图层进行绘制后再合并图层

利用devTools了解网页的图层拆分情况

默认情况下,浏览器会根据他自己的规则来进行图层的拆分。

* 打开layers标签页

在这里插入图片描述

* 查看当前图层

页面若有动画,图层个数会随着动画的变化而变动
在这里插入图片描述

哪些样式仅影响复合

不影响回流和重绘。

Postion
// 指定对象的2D translation(2D平移)。第一个参数对应X轴,第二个参数对应Y轴。如果第二个参数未提供,则默认值为0
transform :translate(<length>[, <length>])
Scale
// 指定对象的2D scale(2D缩放)。第一个参数对应X轴,第二个参数对应Y轴。如果第二个参数未提供,则默认取第一个参数的值
transform :scale(<number>[, <number>])
Rotation
// 指定对象的2D rotation(2D旋转),需先有transform-origin属性的定义
transform :rotate(<angle>)
Opacity
// 使用浮点数指定对象的不透明度。值被约束在[0.0-1.0]范围内,如果超过了这个范围,其计算结果将截取到与之最相近的值。
opacity: 0~1

以上4个是对元素的几何形状或者颜色做变换的,把这些元素独立到一个图层,就不会引起回流和重绘,只会做图层复合。

demo1:查看图层

在这里插入图片描述
以淘宝网为例,如上图,选中图层后会在页面上把对应的元素阴影显示;而当前图层是轮播图,使用单独的图层可以避免轮播图变换时不引起其他图层元素的回流和重绘。

demo2:性能分析

在这里插入图片描述
如上图,轮播图在循环播放时,并没有重绘,只是做了 更新图层和新的图层合并。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值