在性能优化中有一种手段叫做预加载,从字面意思理解就是提前加载页面所依赖的资源,在网络请求中,我们在使用到某些资源如:图片,JS,css等,在执行前总需要等待资源的下载,若我们能做到预先加载资源,则在资源执行的时候就不必等待网络的开销,从而可以达到加快渲染的效果。而预加载常用的属性主要有两个:「preload」、「prefetch」
Preload主要是让浏览器提前加载资源(加载后并不会立即执行),然后会在需要执行的时候执行。并且 onload 事件必须等页面所有资源都加载完成才触发,而当给某个资源加上 preload 后,该资源将不会阻塞 onload。
通过link标签创建
<!-- 使用 link 标签静态标记需要预加载的资源 -->
<link rel="preload" href="style.css" as="style">
<!-- 或使用脚本动态创建一个 link 标签 -->
<script>
const link = document.createElement('link');
link.rel = 'preload';
link.as = 'style';
link.href = 'style.css';
document.head.appendChild(link);
</script>
在HTTP响应头中加上preload字段
Link: <https://xxx.com/static/styles.css>; rel=preload; as=style
比如页面同时加载了两个JS文件
<script src="./js/a.js"></script>
<script src="./js/b.js"></script>
正常来讲它们的加载顺讯应该与书写顺序一致。
我们给b.js配置预加载
<link rel="preload" as="script" href="./js/b.js" />
再来看一下它俩的加载顺序:
此时b.js已经在a.js之前进行加载了。
preload 除了能够预加载脚本之外,还可以通过 as 指定别的资源类型,比如:
「预加载字体」
preload比较常见的使用场景是用于字体文件的预加载,开发过程中处于对设计的高度还原,我们可能会使用自定义字体。但在使用过程中我们往往会遇到下面这种现象,页面首次加载时文字会出现短暂的字体样式闪动(FOUT,Flash of Unstyled Text),在网络情况较差时更加明显。主要原因是字体文件由css引入,在css解析后才会进行加载,加载完成之前浏览器只能使用降级字体。也就是说,字体文件加载的时机太迟,需要告诉浏览器提前进行加载,这恰恰是preload的用武之地。
当我们为字体文件加上预加载后再来看看效果
<link rel="preload" as="font" crossorigin href="https://xxx/229c49c5.6rzn36.ttf">
再次刷新页面,我们可以看到页面没有出现文字样式闪动了,并且我们在network面板中可以看到字体文件的加载时机提前了,在浏览器请求html后很快就开始加载字体文件了。
const isPreloadSupported = () => {
const link = document.createElement('link');
const relList = link.relList;
if (!relList || !relList.supports) {
return false;
}
return relList.supports('preload');
};
preload 用于提前加载用于当前页面的资源,而 prefetch 则是用于加载未来(比如下一个页面)会用到的资源,并且告诉浏览器在空闲的时候去下载,它会将下载资源的优先级降到最低。
通过link标签创建
<!-- 使用 link 标签静态标记需要预加载的资源 -->
<link rel="prefetch" href="style.css" as="style">
<!-- 或使用脚本动态创建一个 link 标签 -->
<script>
const link = document.createElement('link');
link.rel = 'prefetch';
link.as = 'style';
link.href = 'style.css';
document.head.appendChild(link);
</script>
在HTTP响应头中加上preload字段
Link: <https://xxx.com/static/styles.css>; rel=prefetch; as=style
还是上面这个例子
<script src="./js/a.js"></script>
<script src="./js/b.js"></script>
正常来讲它们的加载顺讯应该与书写顺序一致。
我们给a.js配置prefetch
<link rel="prefetch" as="script" href="./js/b.js" />
再来看一下它俩的加载顺序:
此时我们会发现a.js的加载优先级已经降到最低了,当资源被下载完成后,会被存到浏览器缓存中,当从首页跳转到页面 A 的时候,假如页面 A 中引入了该脚本,那么浏览器会直接从 prefetch cache 中读取该资源,从而实现资源加载优化。
来源公众号:前端南玖
懒加载也就是延迟加载,好处是页面加载速度快、可以减轻服务器的压力、节约了流量,用户体验好。预加载:提前加载图片,当用户需要查看时可直接从本地缓存中渲染
用户体验一直是前端开发需要考虑的重要部分,在数据请求时常见到锁屏的loading动画,而现在越来越多的产品倾向于使用Skeleton Screen Loading(骨架屏)替代,以优化用户体验
不管是浏览器的开发者还是普通web应用的开发者,他们都在做一个共同的努力:让Web浏览有更快的速度感觉。有很多已知的技术都可以让你的网站速度变得更快
作为网页内容的一部分,图像和视频通常要消耗很多资源加载。要提高网页应用的性能,如何避免资源浪费在加载图像和视频上就很重要了。但是,很多时候我们都不愿意减少网页上的媒体资源,所以我们经常无从下手。
你可以在页面 <head> 元素内部使用 <link> 标签书写一些声明式的资源获取请求,有些资源是在页面加载完成后即刻需要的,对于这种即刻需要的资源,你可能希望在页面加载的生命周期的早期阶段就开始获取
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!