DOM
树和CSSDOM
树。HTML
会转换成文档对象模型DOM
,CSS
会转换成CSS
对象模型CSSDOM
。它们两个是互相独立的数据结构。DOM
和CSSDOM
组合在一块儿造成渲染树。javascript
DOM
树节点DOM
节点用合适的CSSDOM
规则去匹配浏览器将页面渲染好以后,后面是如何动态更新样式的:java
javascript
动态更新根据选择器匹配对应的DOM
,计算出style
是布局仍是样式,以下图所示:web
layout
将不会触发layout
和paint
都不会触发,只会触发最后的composite
部分,好比动画CSS
中使用动画,有两种属性能够实现,一种是transition
和animation
,它俩的区别从名字中也能够看出来:浏览器
transition
是过渡的意思,它只有开始帧和结束帧,中间的过程浏览器用你指定的属性自动完成,你没法本身控制animation
是动画的意思,它包含多个关键帧,经过控制帧,能够作出复杂的动画参考文章:
Render-tree Construction, Layout, and Paint
Stick to Compositor-Only Properties and Manage Layer Count数据结构