Javascript图片懒加载

懒加载的意义

懒加载的主要目的是作为服务器前端的优化,减少请求数或延迟请求数。

懒加载的实现

  • 1.第一种是纯粹的延迟加载,使用setTimeOut或setInterval进行加载延迟.

  • 2.第二种是条件加载,符合某些条件,或触发了某些事件才开始异步下载。

  • 3.第三种是可视区加载,即仅加载用户可以看到的区域,这个主要由监控滚动条来实现,一般会在距用户看到某图片前一定距离遍开始加载,这样能保证用户拉下时正好能看到图片。

延迟加载

function createImg(url){
  var img = new Image();
  img.src = url;
  return img
}
setTimeOut(() => {
createImg('./images/1.jpg')
})

可视区加载

HTML代码

 <img data-src="./images/1.jpg" alt="">
 <img data-src="./images/2.jpg" alt="">
 <img data-src="./images/3.jpg" alt="">
 <img data-src="./images/4.jpg" alt="">
 <img data-src="./images/5.jpg" alt="">
 <img data-src="./images/4.jpg" alt="">

JavaScript代码

var imgs = document.querySelectorAll('img');
//offsetTop是元素与offsetParent的距离,循环获取直到页面顶部
function getTop(e) {
  var T = e.offsetTop;
  while(e = e.offsetParent) {
    T += e.offsetTop;
  }
    return T;
}

function lazyLoad(imgs) {
  var H = document.documentElement.clientHeight;//获取可视区域高度
  var S = document.documentElement.scrollTop || document.body.scrollTop;
  for (var i = 0; i < imgs.length; i++) {
    if (H + S > getTop(imgs[i])) {
      imgs[i].src = imgs[i].getAttribute('data-src');
    }
  }
}

window.onload = window.onscroll = function () { //onscroll()在滚动条滚动的时候触发
  lazyLoad(imgs);
}
posted @ 2021-04-12 15:08  亓亓哟  阅读(61)  评论(0编辑  收藏  举报