CSS 如何影响首次加载时的白屏时间的解决方法

2019-08-28 0 1,006

含有外部 css 文件渲染流水线

CSS 如何影响首次加载时的白屏时间的解决方法

上图中,请求 HTML 数据和构建 DOM 中间有一段空闲时间,这段时间可能成为页面渲染的瓶颈。DOM 构建结束后,css 文件还未下载完成这段时间内,渲染流水线一直在等待,因为下一步是合成布局树。合成布局树需要 CSSOM 和 DOM,所以需要等待 CSS 加载结束并解析为 CSSOM。这种情况下,CSS 没有阻塞 DOM 的生成。

CSSOM 的作用

提供给 JS 操作样式表的能力 为布局树合成提供基础的样式信息

含有内联 JS 和 外部 CSS 页面的渲染流水线

CSS 如何影响首次加载时的白屏时间的解决方法

从上图中可以看到,构建 DOM 过程中遇到 JS 会停止构建,去解析执行 JS,因为 JS 可能会修改当前 DOM。

在执行 JS 脚本之前,若页面中包含外部 css 或内联的 css,渲染引擎需要将他们提前转为 CSSOM,因为 JS 有修改 CSSOM 的能力,所以在 JS 执行前,还要依赖 CSSOM。 这意味着 CSS 在部分情况下也会阻塞 DOM 生成。

含有外部 JS 和 CSS 页面的渲染流水线

CSS 如何影响首次加载时的白屏时间的解决方法

请求到的 HTML 数据在预解析过程中,检测到有外部 JS、CSS 文件需要下载,同时发起两个文件的下载请求,下载时间不是重叠的,是按照最久的那个来算。

不管 CSS,JS 谁先到达,都要先等到 CSS 文件下载并生成 CSSOM,然后执行 JS 脚本,最后构建 DOM、布局树、绘制页面。

影响页面展示因素及优化策略

从输入 URL 到页面首次展示的三阶段:

最影响用户体验的就是第二阶段,包括解析 HTML、下载 CSS、下载 JavaScript、生成布局树、绘制页面等操作。

优化策略

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

本知识来源于互联网索引,如有侵权请联系我们!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在!
点赞 (0)

1、寻代码所有源码、代码、教程和软件均为作者提供和网友推荐收集整理而来!
2、寻代码提供的所有模块、软件等资源,均不提供任何技术服务,请知悉!
3、如您需要商用,请支持正版,寻代码网站所提供的程序仅供学习和研究使用!
4、寻代码源码不得使用于非法商业用途,不得违反国家法律。您必须在下载后24小时内删除!
5、寻代码资源每天实时更新,如遇压缩包解压密码,一律为:www.xundm.com
6、寻代码资源售价和VIP会员只是赞助,收取费用仅维持本站的日常运营所需!
7、如有链接无法下载、失效或广告,请在会员中心下工单!
如有侵犯您版权的,请来信(邮箱:[email protected])指出,本站将立即改正。

寻代码 网站制作 CSS 如何影响首次加载时的白屏时间的解决方法 https://xundm.com/201911910.html

常见问题
  • 当然可以,寻代码每日签到奖励1寻币,推广注册奖励5寻币,只要坚持关注和推广我们站,您可以免费下载全站资源
查看详情
  • 寻代码所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 赞助VIP介绍。
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言或在会员中心直接提交工单 。
查看详情
  • 对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
查看详情

相关文章

寻代码站内服务

为您解决烦忧 - 24小时在线 专业服务