让前端飞Web前端之路svelte

前端笔记(11)提升首屏加载速度

2020-05-31  本文已影响0人  sullay

首屏加载速度影响着用户对整个网站的第一体验尤为关键。那么如果才能够优化首次加载时的白屏时间?
上一篇文章简单介绍了在浏览器里,从输入 URL 到页面展示的过程。现在我们将整个过程划分为三个阶段:

1.从请求发出后到文档提交阶段,这个阶段中用户看到的还是跳转前的上一个页面。
2.文档提交以后,渲染进程创建一个空白页面,并等待css、javascript的加载,生成CSSOM和DOM,然后构建布局树渲染页面。
3.页面渲染完成以后进入页面绘制阶段。

影响第一个阶段的主要因素是网络以及服务器。影响第三个阶段主要因素是浏览器的性能已经用户的主机性能。
这里我们主要分析第二个阶段。这个阶段如果处理的不好就会存在过长的白屏时间严重影响体验。我们再次分解第二个阶段:

在这其中下载javascript以及执行javascript会阻塞DOM树的构建,下载css虽然不会直接阻塞DOM树的构建但是JavaScript执行需要等css下载完成以后,因此也可能阻塞DOM树的构建。

由于css代码不会阻塞DOM构建所有我们可以将其应该尽量靠前。

javascript代码无论放在任何位置都会阻塞DOM树的构建,我可以将不存在dom操作的JavaScript代码放在css之前,使其不受css下载的影响。将存在dom操作的JavaScript代码放在尽量靠后的位置,使其可以操作dom的同时尽可能与css距离足够远尽可能减少受css下载影响的可能性。

因此我们可以通过以下几种手段优化首屏加载速度:

实际场景中还需要根据情况进行分析,找出影响页面首屏速度关键点。例如针对单页面应用使用服务端渲染首屏、使用浏览器的强缓存与协商缓存。

上一篇 下一篇

猜你喜欢

热点阅读