浏览器渲染及动画

本文探讨了浏览器渲染页面的原理,从构建DOM和CSSOM到形成渲染树,并详细阐述了样式更新过程中如何动态改变样式,以及如何判断是否触发重新布局或重绘。重点讲解了CSS动画,区分了transition和animation的差异,强调了如何优化以避免不必要的渲染操作。
摘要由CSDN通过智能技术生成

浏览器渲染原理:

  1. 浏览器在渲染页面之前会先构建DOM树和CSSDOM树。
  2. HTML会转换成文档对象模型DOMCSS会转换成CSS对象模型CSSDOM。它们两个是互相独立的数据结构。
  3. DOMCSSDOM组合在一起形成渲染树。
    1. 遍历DOM树节点
    2. 对每个DOM节点用合适的CSSDOM规则去匹配
    3. 计算出最终布局,样式
  4. 最后将它们合并到一起,渲染在页面中

2.png

样式更新

浏览器将页面渲染好之后,后面是如何动态更新样式的:

  • 通过javascript动态更新
  • 根据选择器匹配对应的DOM,计算出style是布局还是样式,如下图所示:
    1. 如果是更改布局,是会依次触发
    2. 如果布局没有改动,只是更改了颜色之类的,layout将不会触发
    3. 如何既不改布局,也不改样式啥的,layoutpaint都不会触发,只会触发最后的composite
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值