Js实现图片的懒加载

  在有些时候,我们在前端加载的图片就很多,例如商城之类的网站,图片就很多,那么,我们一次性加载所有的图片的肯定会影响性能,而且会占用宽带

  为了解决以上的问题,就出现了懒加载方式来减轻加载的压力,优先加载可视区域的内容,其他部分等进入可视区域再加载,从而提高性能

  (vue项目的打包中,是把html、css、js进行打包,还有就是图片的压缩。但是打包时把js和css都分成了几个部分,这样就不至于一个css和js文件非常大。也是提高性能的一种方式)

  那么下边我们就来具体说一说这个图片懒加载的原理以及实现:

 

 

 这就是简单的懒加载,就是在使用滚动条的时候,图片才实现可视区域的加载

一.原理

  一张图片就是一个<img>标签,浏览器是否发起请求是根据<img>的src属性决定的,所以实现图片的懒加载的关键就是,在图片没有进入可视化区域时,先不给<img>的src属性赋值,这样浏览器就不会发送请求,等到图片进入可视区域之后,再给src属性进行赋值即可

二.懒加载的思路及实现

  1.加载可视区域的图片

  2.判断图片是否需要加载

  3.隐形加载图片

  4.替换真图片

    (1)加载当页面显示时就在可视区域的图片

      

 

 

     (2)那么我们如何去判断是否进入可视区域呢?   我们先来看一下一个网页的整体的区域的划分

      

      如上图所示,让在浏览器可视区域的图片显示,可视区域外的不显示,所以当图片距离顶部的距离top-height等于可视区域h和滚动区域高度s之和时说明图片马上就要进入可视区了,就是说当top-height<=s+h时,图片在可视区。
      这里介绍下几个API函数:
      页可见区域宽: document.body.clientWidth;
      网页可见区域高: document.body.clientHeight;
      网页可见区域宽: document.body.offsetWidth (包括边线的宽);
      网页可见区域高: document.body.offsetHeight (包括边线的宽);
      网页正文全文宽: document.body.scrollWidth;
      网页正文全文高: document.body.scrollHeight;
      网页被卷去的高: document.body.scrollTop;
      网页被卷去的左: document.body.scrollLeft;
      网页正文部分上: window.screenTop;
      网页正文部分左: window.screenLeft;
      屏幕分辨率的高: window.screen.height;
      屏幕分辨率的宽: window.screen.width;
      屏幕可用工作区高度: window.screen.availHeight;

    代码实现如下:    

// onload是等所有的资源文件加载完毕以后再绑定事件
window.onload = function(){
    // 获取图片列表,即img标签列表
    var imgs = document.querySelectorAll('img');

    // 获取到浏览器顶部的距离
    function getTop(e){
        return e.offsetTop;
    }

    // 懒加载实现
    function lazyload(imgs){
        // 可视区域高度
        var h = window.innerHeight;
        //滚动区域高度
        var s = document.documentElement.scrollTop || document.body.scrollTop;
        for(var i=0;i<imgs.length;i++){
            //图片距离顶部的距离大于可视区域和滚动区域之和时懒加载
            if ((h+s)>getTop(imgs[i])) {
                // 真实情况是页面开始有2秒空白,所以使用setTimeout定时2s
                (function(i){
                    setTimeout(function(){
                        // 不加立即执行函数i会等于9
                        // 隐形加载图片或其他资源,
                        //创建一个临时图片,这个图片在内存中不会到页面上去。实现隐形加载
                        var temp = new Image();
                        temp.src = imgs[i].getAttribute('data-src');//只会请求一次
                        // onload判断图片加载完毕,真是图片加载完毕,再赋值给dom节点
                        temp.onload = function(){
                            // 获取自定义属性data-src,用真图片替换假图片
                            imgs[i].src = imgs[i].getAttribute('data-src')
                        }
                    },2000)
                })(i)
            }
        }
    }
    lazyload(imgs);

    // 滚屏函数
    window.onscroll =function(){
        lazyload(imgs);
    }
}

 

 

    

           这样就实现了图片的懒加载了

    开始的时候三张图片在可视区域,所以发起三次请求

    

 

     随着鼠标的向下滚动,其余图片也逐渐显示并发起请求

    

 

       动态的效果如下:

      

  一个简单的图片的懒加载就实现完成了

 

posted @ 2020-07-25 09:56  杨超(yc)  阅读(265)  评论(0编辑  收藏  举报