- 浏览器控件加载
HTML5
页面的HTML
主文档。 - 加载过程中遇到外部
CSS
文件,浏览器另外发出一个请求,来获取CSS
文件。 - 遇到图片资源,浏览器也会另外发出一个请求,来获取图片资源。这是异步请求,并不会影响 HTML 文档的加载。
- 加载过程中遇到
JavaScript
文件,由于JavaScript
代码可能会修改DOM
树,因此HTML
文档会挂起渲染(加载解析渲染同步)的线程,直到JavaScript
文件加载解析并执行完毕,才可以恢复HTML
文档的渲染线程。 JavaScript
代码中有用到CSS
文件中的属性样式,于是阻塞,等待CSS
加载完毕才能恢复执行。
- 浏览器在渲染页面之前会先构建
DOM
树和CSSDOM
树。 HTML
会转换成文档对象模型DOM
,CSS
会转换成CSS
对象模型CSSDOM
。它们两个是互相独立的数据结构。DOM
和CSSDOM
组合在一起形成渲染树。- 遍历
DOM
树节点 - 对每个
DOM
节点用合适的CSSDOM
规则去匹配 - 计算出最终布局,样式
- 遍历
- 最后将它们合并到一起,渲染在页面中
浏览器将页面渲染好之后,后面是如何动态更新样式的:
- 通过
javascript
动态更新 - 根据选择器匹配对应的
DOM
,计算出style
是布局还是样式,如下图所示:- 如果是更改布局,是会依次触发
- 如果布局没有改动,只是更改了颜色之类的,
layout
将不会触发 - 如何既不改布局,也不改样式啥的,
layout
和paint
都不会触发,只会触发最后的composite
部分,比如动画
CSS
中使用动画,有两种属性可以实现,一种是transition
和animation
,它俩的区别从名字中也可以看出来:
transition
是过渡的意思,它只有开始帧和结束帧,中间的过程浏览器用你指定的属性自动完成,你无法自己控制animation
是动画的意思,它包含多个关键帧,通过控制帧,可以做出复杂的动画