当前位置:网站首页>图片的懒加载和预加载
图片的懒加载和预加载
2022-06-28 02:48:00 【weixin_47164846】
图片懒加载和预加载
一.背景
目前各种电商网站层出不穷,大家都知道,电商网站的图片量是非常之多的,其实也不只是电商网站,更有些其他的,图片密集度比较大的网站.由于图片数目较大,等待时间长,并且加载过多的资源,导致些资源浪费,那这种情况,用户体验度就是非常差的了,所以这个时候,懒加载和预加载就是个非常好的解决方案
二.懒加载
懒加载:又名延迟加载(简称lazyload),可以在长网页中延迟加载图像,是对网页性能优化的的一种方案,它的核心是按需加载
1.为什么要使用懒加载?
(1) 提升用户体验 如果一个长网页,一次性把图片全部加载出来,图片密集度非常之高,数目较大,等待时间之久,用户肯定不买账,直接关闭网页走人.
(2) 减少无效资源加载 按需要去加载数据,没有进入视口的不需要加载,你根本没看他们,加载出来干嘛.所以明显减少服务器的压力和流量,也能减少浏览器的渲染负担
(3) 防止并发加载的资源过多,阻塞js的加载 影响网站的正常使用
2.实现懒加载思路
(1) 利用Image的src有图片地址时才会加载图片
(2) 图片的初始状态不设置src属性,使用一个自定义属性保存图片路径 如data-src
(3) 图片进入窗口可视区时给src赋值
(4) window.onscroll判断图片是否进入窗口:图片到body的offsetTop<(窗口高+scrollTop)
3.懒加载原理
将页面上的图片src属性设置为空,然后将图片的真实路径存放在当前图片标签的自定义属性data-src上,当页面滚动的时候,需要去监听scroll事件,在scroll事件的回调中,判断我们的懒加载的图片是否进入可视区域,如果图片在可视区域就将图片的src属性设置为data-src的值,然后这样就实现延迟加载
注意:如果是异步加载的数据,我们实际上只需要做一次请求即可,不需要多次请求
4.实现懒加载
<style>
.image-item {
display: block;
margin-bottom: 50px;
height: 200px;
/* 一定记得设置图片高度 */
}
</style>
//html
<img src="" class="image-item" lazyload="true" data-src="https://image.ztemall.com/e96bedfde1da7fe4430015588ded9e55.jpg"
<img src="" class="image-item" lazyload="true" data-src="https://image.ztemall.com/f4eb114554ae8d3d11a11bf0fa436b4a.jpg"
//html
<img src="" class="image-item" lazyload="true" data-src="https://image.ztemall.com/e96bedfde1da7fe4430015588ded9e55.jpg"
<img src="" class="image-item" lazyload="true" data-src="https://image.ztemall.com/f4eb114554ae8d3d11a11bf0fa436b4a.jpg"
//js
<script>
var viewHeight = document.documentElement.clientHeight;//获取可视区高度
function lazyload() {
var eleImgs= document.querySelectorAll('img[data-src][lazyload]');
eleImgs.forEach(function (item, index) {
//如果data-src属性没有值,直接返回
if (item.dataset.src === "")
return;
// 用于获得页面中某个元素的左,上,右和下分别相对浏览器视窗的位置
var rect = item.getBoundingClientRect();
if (rect.bottom >= 0 && rect.top < viewHeight) {
(function () {
var img = new Image();
img.src = item.dataset.src;
img.onload = function () {
item.src = img.src;
}
item.removeAttribute("data-src");//移除属性,下次不再遍历
item.removeAttribute("lazyload");
})()
}
})
}
lazyload();//刚开始还没滚动屏幕时,要先触发一次函数,初始化首页的页面图片
document.addEventListener("scroll", lazyload);
</script>
三.预加载
预加载:提前加载图片,当用户需要查看时,直接从本地缓存中去渲染资源预加载是网页的另一个性能优化技术,我们可以使用该技术来预先告知浏览器某些资源可能在将来会被使用到.
1.为什么要使用预加载
在网页全部加载之前,对一些主要内容进行加载,提供给用户更好的体验,减少等待的时间,如果一个长页面,过于庞大,没有使用预加载,页面就会长时间展现为一片空白,直到所有内容加载完毕
2.实现预加载思路
(1) 创建好要显示的图片节点1
(2) 创建用来加载图片的节点2
(3) 监听节点2的onload事件
(4) 返回一个对象,包含一个设置图片src的方法,节点1显示本地图片,节点2加载真正的资源
3.实现预加载常见方法
1.使用HTML标签
<img src="https://image.ztemall.com/e96bedfde1da7fe4430015588ded9e55.jpg" style="display:none"/>
2.使用Image对象
var image= new Image()
image.src="https://image.ztemall.com/e96bedfde1da7fe4430015588ded9e55.jpg"
3.使用ajax
这里不做介绍,会存在一些跨域问题
四.懒加载和预加载区别
1.概念
(1) 懒加载(延迟加载):图片延迟加载,当图片进入视口之后才加载
(2) 预加载:提前加载图片,当用户需要查看时,直接从本地缓存读取
2.区别
二者都是提高页面性能的有效办法,区别是一个是提前加载,一个是延迟加载甚至不加载,懒加载对服务器前端有一定的缓解压力的作用,预加载则会增加服务器前端的压力
3.意义
(1) 懒加载的主要目的是作为服务器前端的优化,减少请求数或延迟请求数。
(2) 预加载可以说是牺牲服务器前端性能,换取更好的用户体验,这样可以使用户的操作得到最快的反映
边栏推荐
猜你喜欢

composition api在项目中的使用总结

STM32外设SDIO和SD卡的配置

荣耀v8 真机调试时不显示 Logcat 日志的解决办法

Object class, and__ new__,__ init__,__ setattr__,__ dict__

Question bank and answers of special operation certificate for R1 quick opening pressure vessel operation in 2022

开口式霍尔电流传感器如何助力直流配电改造?

mysql获取当前时间是一年的第多少天

collections. Use of defaultdict()

導入Excel文件,解决跳過空白單元格不讀取,並且下標前移的問題,以及RETURN_BLANK_AS_NULL報紅

"Five layer" architecture of cloud applications and services
随机推荐
"9 No" principle and "5 measurement dimensions" of extensible system
matlab习题 —— 符号运算相关练习
启牛商学院赠送证券账户是真的吗?开户到底安不安全呢
composition api在项目中的使用总结
Redis cluster setup [simple]
No&nbsp;result&nbsp;defined&amp;nbsp…
调试利器 go-spew
数据库的迁移
可扩展数据库(下)
数据库系列之MySQL中的执行计划
Win 10出现bitlocke恢复,蓝屏错误代码0x1600007e
用于 C# 的 SQL 基本语法总结
SSH框架的搭建(上)
mysql获取当前时间是一年的第多少天
十年职场软件工程师感悟
What are the technologies to be mastered in the test? Database design for software testing
Tardigrade:Trino 解决 ETL 场景的方案
17 `bs object Node name h3 Parent ` parents get parent node ancestor node
Tencent games released more than 40 products and projects, including 12 new games
Basic operation of stack (implemented in C language)