对于目前的图片懒加载,我们一般采用的是通过第三方库或懒加载库来实现,但是该方式的显著问题就是,必须按顺序执行:
1、加载初始的 HTML 响应内容
2、加载懒加载库
3、加载图片
假如浏览器能直接支持懒加载,那是最好的,这一想法也不是不可能哦!从Chrome 75开始,我们可以通过切换两个开关来手动启用懒加载功能,可能最新的Chrome将会默认开启懒加载功能了,就是说不用我们手动去设置了。(注意这里仅说到了是Chrome浏览器哦)
loading特性的原理:
原生懒加载功能使用了一种预检请求来获取图片文件的前2048字节数据。根据预先取得的数据,浏览器会试着确定该图片的大小,在第一个(如果图片大小小于2KB,一个预检请求就够了)或第二次请求完成后,完整图片一加载完毕,其load事件就会解除监听。
我们可以通过一段脚本来判断浏览器是否支持懒加载功能,如果支持,可直接在img标签中写上loading并设置相关的值即可轻松实现懒加载,loading有三个值,分别是auto(默认值,浏览器自行决定是否启用懒加载)、eager(直接加载该图片)、lazy(开启懒加载)。
对程序员,web前端感兴趣,想要了解学习的,打算深入了解这个行业的朋友,可以加下我们的前端学习扣qun : 784783012 ,不论你是学生还是想转行的朋友,我都欢迎,不定期分享干货,整理的一份2019最新的web前端学习资料和0基础入门教程分享给大家,学习前端我们是认真的
使用以下脚本可以判断浏览器是否支持原生懒加载功能:
<script>
if("loading" in HTMLImageElement.prototype){
alert("支持");
}else{
alert("不支持,你可能需要引入懒加载库来实现懒加载");
}
</script>
如果支持,我们可以在img标签中为loading指定值:
<img src="" alt="浏览器自行决定是否启用懒加载" loading="auto">
<img src="" alt="浏览器立即加载该图片" loading="eager">
<img src="" alt="浏览器使用懒加载" loading="lazy">
web前端开发学习Q-q-u-n: 784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)
本文介绍了HTML原生懒加载技术,从Chrome 75版本开始,浏览器支持原生懒加载功能,通过预检请求获取图片前2048字节数据来判断加载策略。loading特性有auto、eager和lazy三个值,分别对应不同加载行为。开发者可以利用此功能提高网页性能,减少不必要的资源加载。提供了一个检测浏览器是否支持懒加载的脚本,并鼓励对web前端感兴趣的学习者深入研究。
5万+





