图片懒加载

图片懒加载

在实际的项目开发中,我们经常遇到这样的情况:一个页面要展示的图片很多,但是在首屏出现的图片只有几张。如果我们一次性把所有的图片都加载出来,会影响页面的渲染速度,还浪费带宽。我们需要做的就是把首屏的图片先展示,不可视区域的图片不展示,等图片到达可视区域的时候再加载,这就是我们图片懒加载。

思路:

将页面里所有img属性src属性用data-xx代替,当页面滚动直至此图片出现在可视区域时,用js取到该图片的data-xx的值赋给src,同时移除data-xxx属性。

懒加载判断条件如下图所示
js懒加载图片.png

html结构

 ![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip) 

  1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>1<br/>
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip)
![](http://upload-images.jianshu.io/upload_images/3453618-e31c0108123ec0b7.gif?imageMogr2/auto-orient/strip) 

这里用多行1来实现部分图片在不可视区域,以上src的属性用占位图来替代,实际的图片地址绑定在data-src属性上。这样首屏的时候实际就加载了一张图片。

第一种(javascript)

(function(){

    var imgList,
        time = 250,
        delay,imgH,
        offset = 100;

   
     function _delay(obj){
         clearTimeout(delay);
         delay = setTimeout(function(){
            _imgload(obj);
         },time);
     }

     function _imgload(obj){
        imgH = obj[0].offsetHeight;
       // console.log(imgH);
        for(var i = 0,len = obj.length ; i < len ; i ++){
            if(obj[i].getAttribute('data-src')){
                 if(_isShow(obj[i])){
                   obj[i].src = obj[i].getAttribute('data-src');
                   obj[i].removeAttribute('data-src');
                }
            }  
        }
     }

     function _isShow(el){
        var coords = el.getBoundingClientRect();
         //console.log(coords);
         var left = coords.left ,
             top = coords.top,
             winH = document.documentElement.clientHeight || window.innerHeight;
        // return left >=0 && ( top >= 0 || top > - imgH ) && ( top <= winH + parseInt(offset) );   //只加载可视区域的图片            
            return left >=0 && top <= winH + parseInt(offset) //可视区域以上的图片也加载
     }
    
     function imgLoad(selector){

        var selector = selector || '.imgLazyLoad',
            node = document.querySelectorAll(selector),
            imgList = Array.apply(null,node);
        _delay(imgList);
        window.addEventListener('scroll',function(){
              _delay(imgList);
        },false);
     }
  
    imgLoad('.imgLazyLoad');
   

})();

第二种(jquery)

!(function($){
    /*
     options是个对象 非必填
     */
    $.fn.imgLazyLoad = function(options){
         var _windowH = $(window).height(),
             _delay, //函数节流
             _scrollTop = $(window).scrollTop();

         //默认参数
         var defaults = {
             time:500, //图片延迟加载的时间
             offset:250, //图片预加载的距离,
             className:"data-src"
         } ;
         var that = this;
         var options = $.extend({},defaults,options);
         

         function picLazyLoad(){
              clearTimeout(_delay);
              _delay = setTimeout(function(){
                  that.each(function(index,value){
                    //console.log($(value).offset().top);
                    if($(value).attr(options.className)){
                        _scrollTop = $(window).scrollTop();
                        if($(value).offset().top <= _windowH + _scrollTop + options.offset){
                            $(value).attr("src",$(value).attr(options.className));
                            $(value).removeAttr(options.className);
                        }
                    }
                    
                
                  });
              },options.time);

         } 

         $(window).on('scroll',function(){
                picLazyLoad();
         });
        picLazyLoad();
    };

})(jQuery);

使用方法:

(function(){
    
       $('.imgLazyLoad').imgLazyLoad({
        time:50, //间隔时间
        offset:100,//图片距离可视区域的偏移距离
        class:"data-src"
       });
})();

源码参考 https://github.com/chunxiao1991/imgLazyLoad

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容