时间:2021-05-08
含有外部 css 文件的渲染流水线
上图中,请求 HTML 数据和构建 DOM 中间有一段空闲时间,这段时间可能成为页面渲染的瓶颈。DOM 构建结束后,css 文件还未下载完成这段时间内,渲染流水线一直在等待,因为下一步是合成布局树。合成布局树需要 CSSOM 和 DOM,所以需要等待 CSS 加载结束并解析为 CSSOM。这种情况下,CSS 没有阻塞 DOM 的生成。
CSSOM 的作用
含有内联 JS 和 外部 CSS 页面的渲染流水线
从上图中可以看到,构建 DOM 过程中遇到 JS 会停止构建,去解析执行 JS,因为 JS 可能会修改当前 DOM。
在执行 JS 脚本之前,若页面中包含外部 css 或内联的 css,渲染引擎需要将他们提前转为 CSSOM,因为 JS 有修改 CSSOM 的能力,所以在 JS 执行前,还要依赖 CSSOM。 这意味着 CSS 在部分情况下也会阻塞 DOM 生成。
含有外部 JS 和 CSS 页面的渲染流水线
请求到的 HTML 数据在预解析过程中,检测到有外部 JS、CSS 文件需要下载,同时发起两个文件的下载请求,下载时间不是重叠的,是按照最久的那个来算。
不管 CSS,JS 谁先到达,都要先等到 CSS 文件下载并生成 CSSOM,然后执行 JS 脚本,最后构建 DOM、布局树、绘制页面。
影响页面展示因素及优化策略
从输入 URL 到页面首次展示的三阶段:
最影响用户体验的就是第二阶段,包括解析 HTML、下载 CSS、下载 JavaScript、生成布局树、绘制页面等操作。
优化策略
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1、问题描述本地的vue项目在server端浏览没问题,但是执行npmrunbuild打包之后在本地预览是白屏。有很多js,css无法加载。2、解决方法在con
浏览器出现白屏往往在浏览网页时,页面空然出现白屏,刷新也不显示,页面已经加载完,有的时候还有黑白快速交替爆闪现象。下面是解决方法。 1、造成这种现象的原因是新
ios7越狱cydia白屏怎么办?下文将为大家介绍越狱后cydia白屏解决方法,有很多果粉表示进行完美越狱之后会出现cydia白屏的故障,该如何解决呢?请看
电脑白屏解决方法:机箱散热不好,显卡温度升高引起的白屏。解决方法就是,排除散热问题。检查风扇运转是否正常,给风扇加油,清理机箱内的灰尘,解决散热问题后故障即可排
在项目开发中遇到这样的功能,要求实现列表页动态加载功能,在实现过程中遇到一些小小插曲,下面小编给大家详细说明下解决方法:首次加载时图片可以获取成功,再次加载失败