zoukankan      html  css  js  c++  java
  • jq图片懒加载

    jQuery图片延迟加载插件jQuery.lazyload,使用延迟加载在可提高网页下载速度。在某些情况下,它也能帮助减轻服务器负载。

    使用方法

    引用jquery和jquery.lazyload.js到你的页面

    <script src="jquery-1.11.0.min.js"></script>
    <script src="jquery.lazyload.js?v=1.9.1"></script>

    html图片调用方法

    为图片加入样式lazy  图片路径引用方法用data-original

    <img class="lazy" data-original="img/bmw_m1_hood.jpg">
    <img class="lazy" data-original="img/bmw_m1_side.jpg">
    <img class="lazy" data-original="img/viper_1.jpg">
    <img class="lazy" data-original="img/viper_corner.jpg">
    <img class="lazy" data-original="img/bmw_m3_gt.jpg">
    <img class="lazy" data-original="img/corvette_pitstop.jpg">

    js出始化lazyload并设置图片显示方式

    <script type="text/javascript" charset="utf-8">
      $(function() {
          $("img.lazy").lazyload({effect: "fadeIn"});
      });
    </script>
    在图片中也可以不使用 class="lazy",初始化时使用:
    
    $("img").lazyload({effect: "fadeIn"});

    这样就可以对全局的图片都有效!

     参数设置

    $("img.lazy").lazyload({
      placeholder : "img/grey.gif", //用图片提前占位
        // placeholder,值为某一图片路径.此图片用来占据将要加载的图片的位置,待图片加载时,占位图则会隐藏
      effect: "fadeIn", // 载入使用何种效果
        // effect(特效),值有show(直接显示),fadeIn(淡入),slideDown(下拉)等,常用fadeIn
      threshold: 200, // 提前开始加载
        // threshold,值为数字,代表页面高度.如设置为200,表示滚动条在离目标位置还有200的高度时就开始加载图片,可以做到不让用户察觉
      event: 'click',  // 事件触发时才加载
        // event,值有click(点击),mouseover(鼠标划过),sporty(运动的),foobar(…).可以实现鼠标莫过或点击图片才开始加载,后两个值未测试…
      container: $("#container"),  // 对某容器中的图片实现效果
        // container,值为某容器.lazyload默认在拉动浏览器滚动条时生效,这个参数可以让你在拉动某DIV的滚动条时依次加载其中的图片
      failurelimit : 10 // 图片排序混乱时
         // failurelimit,值为数字.lazyload默认在找到第一张不在可见区域里的图片时则不再继续加载,但当HTML容器混乱的时候可能出现可见区域内图片并没加载出来的情况,failurelimit意在加载N张可见区域外的图片,以避免出现这个问题.
    });

     懒加载jquery.lazyload.js  js代码为下边

      1 /*
      2  * Lazy Load - jQuery plugin for lazy loading images
      3  *
      4  * Version:  1.9.3
      5  *
      6  */
      7 
      8 (function($, window, document, undefined) {
      9     var $window = $(window);
     10 
     11     $.fn.lazyload = function(options) {
     12         var elements = this;
     13         var $container;
     14         var settings = {
     15             threshold       : 0,
     16             failure_limit   : 0,
     17             event           : "scroll",
     18             effect          : "show",
     19             container       : window,
     20             data_attribute  : "original",
     21             skip_invisible  : true,
     22             appear          : null,
     23             load            : null,
     24             placeholder     : ""
     25         };
     26 
     27         function update() {
     28             var counter = 0;
     29 
     30             elements.each(function() {
     31                 var $this = $(this);
     32                 if (settings.skip_invisible && !$this.is(":visible")) {
     33                     return;
     34                 }
     35                 if ($.abovethetop(this, settings) ||
     36                     $.leftofbegin(this, settings)) {
     37                         /* Nothing. */
     38                 } else if (!$.belowthefold(this, settings) &&
     39                     !$.rightoffold(this, settings)) {
     40                         $this.trigger("appear");
     41                         /* if we found an image we'll load, reset the counter */
     42                         counter = 0;
     43                 } else {
     44                     if (++counter > settings.failure_limit) {
     45                         return false;
     46                     }
     47                 }
     48             });
     49 
     50         }
     51 
     52         if(options) {
     53             /* Maintain BC for a couple of versions. */
     54             if (undefined !== options.failurelimit) {
     55                 options.failure_limit = options.failurelimit;
     56                 delete options.failurelimit;
     57             }
     58             if (undefined !== options.effectspeed) {
     59                 options.effect_speed = options.effectspeed;
     60                 delete options.effectspeed;
     61             }
     62 
     63             $.extend(settings, options);
     64         }
     65 
     66         /* Cache container as jQuery as object. */
     67         $container = (settings.container === undefined ||
     68                       settings.container === window) ? $window : $(settings.container);
     69 
     70         /* Fire one scroll event per scroll. Not one scroll event per image. */
     71         if (0 === settings.event.indexOf("scroll")) {
     72             $container.bind(settings.event, function() {
     73                 return update();
     74             });
     75         }
     76 
     77         this.each(function() {
     78             var self = this;
     79             var $self = $(self);
     80 
     81             self.loaded = false;
     82 
     83             /* If no src attribute given use data:uri. */
     84             if ($self.attr("src") === undefined || $self.attr("src") === false) {
     85                 if ($self.is("img")) {
     86                     $self.attr("src", settings.placeholder);
     87                 }
     88             }
     89 
     90             /* When appear is triggered load original image. */
     91             $self.one("appear", function() {
     92                 if (!this.loaded) {
     93                     if (settings.appear) {
     94                         var elements_left = elements.length;
     95                         settings.appear.call(self, elements_left, settings);
     96                     }
     97                     $("<img />")
     98                         .bind("load", function() {
     99 
    100                             var original = $self.attr("data-" + settings.data_attribute);
    101                             $self.hide();
    102                             if ($self.is("img")) {
    103                                 $self.attr("src", original);
    104                             } else {
    105                                 $self.css("background-image", "url('" + original + "')");
    106                             }
    107                             $self[settings.effect](settings.effect_speed);
    108 
    109                             self.loaded = true;
    110 
    111                             /* Remove image from array so it is not looped next time. */
    112                             var temp = $.grep(elements, function(element) {
    113                                 return !element.loaded;
    114                             });
    115                             elements = $(temp);
    116 
    117                             if (settings.load) {
    118                                 var elements_left = elements.length;
    119                                 settings.load.call(self, elements_left, settings);
    120                             }
    121                         })
    122                         .attr("src", $self.attr("data-" + settings.data_attribute));
    123                 }
    124             });
    125 
    126             /* When wanted event is triggered load original image */
    127             /* by triggering appear.                              */
    128             if (0 !== settings.event.indexOf("scroll")) {
    129                 $self.bind(settings.event, function() {
    130                     if (!self.loaded) {
    131                         $self.trigger("appear");
    132                     }
    133                 });
    134             }
    135         });
    136 
    137         /* Check if something appears when window is resized. */
    138         $window.bind("resize", function() {
    139             update();
    140         });
    141 
    142         /* With IOS5 force loading images when navigating with back button. */
    143         /* Non optimal workaround. */
    144         if ((/(?:iphone|ipod|ipad).*os 5/gi).test(navigator.appVersion)) {
    145             $window.bind("pageshow", function(event) {
    146                 if (event.originalEvent && event.originalEvent.persisted) {
    147                     elements.each(function() {
    148                         $(this).trigger("appear");
    149                     });
    150                 }
    151             });
    152         }
    153 
    154         /* Force initial check if images should appear. */
    155         $(document).ready(function() {
    156             update();
    157         });
    158 
    159         return this;
    160     };
    161 
    162     /* Convenience methods in jQuery namespace.           */
    163     /* Use as  $.belowthefold(element, {threshold : 100, container : window}) */
    164 
    165     $.belowthefold = function(element, settings) {
    166         var fold;
    167 
    168         if (settings.container === undefined || settings.container === window) {
    169             fold = (window.innerHeight ? window.innerHeight : $window.height()) + $window.scrollTop();
    170         } else {
    171             fold = $(settings.container).offset().top + $(settings.container).height();
    172         }
    173 
    174         return fold <= $(element).offset().top - settings.threshold;
    175     };
    176 
    177     $.rightoffold = function(element, settings) {
    178         var fold;
    179 
    180         if (settings.container === undefined || settings.container === window) {
    181             fold = $window.width() + $window.scrollLeft();
    182         } else {
    183             fold = $(settings.container).offset().left + $(settings.container).width();
    184         }
    185 
    186         return fold <= $(element).offset().left - settings.threshold;
    187     };
    188 
    189     $.abovethetop = function(element, settings) {
    190         var fold;
    191 
    192         if (settings.container === undefined || settings.container === window) {
    193             fold = $window.scrollTop();
    194         } else {
    195             fold = $(settings.container).offset().top;
    196         }
    197 
    198         return fold >= $(element).offset().top + settings.threshold  + $(element).height();
    199     };
    200 
    201     $.leftofbegin = function(element, settings) {
    202         var fold;
    203 
    204         if (settings.container === undefined || settings.container === window) {
    205             fold = $window.scrollLeft();
    206         } else {
    207             fold = $(settings.container).offset().left;
    208         }
    209 
    210         return fold >= $(element).offset().left + settings.threshold + $(element).width();
    211     };
    212 
    213     $.inviewport = function(element, settings) {
    214          return !$.rightoffold(element, settings) && !$.leftofbegin(element, settings) &&
    215                 !$.belowthefold(element, settings) && !$.abovethetop(element, settings);
    216      };
    217 
    218     /* Custom selectors for your convenience.   */
    219     /* Use as $("img:below-the-fold").something() or */
    220     /* $("img").filter(":below-the-fold").something() which is faster */
    221 
    222     $.extend($.expr[":"], {
    223         "below-the-fold" : function(a) { return $.belowthefold(a, {threshold : 0}); },
    224         "above-the-top"  : function(a) { return !$.belowthefold(a, {threshold : 0}); },
    225         "right-of-screen": function(a) { return $.rightoffold(a, {threshold : 0}); },
    226         "left-of-screen" : function(a) { return !$.rightoffold(a, {threshold : 0}); },
    227         "in-viewport"    : function(a) { return $.inviewport(a, {threshold : 0}); },
    228         /* Maintain BC for couple of versions. */
    229         "above-the-fold" : function(a) { return !$.belowthefold(a, {threshold : 0}); },
    230         "right-of-fold"  : function(a) { return $.rightoffold(a, {threshold : 0}); },
    231         "left-of-fold"   : function(a) { return !$.rightoffold(a, {threshold : 0}); }
    232     });
    233 
    234 })(jQuery, window, document);
  • 相关阅读:
    Daily Coding Problem: Problem #994
    Android 开发绕不过的坑:你的 Bitmap 究竟占多大内存?(转)
    1087.Brace-Expansion (prime)
    Ant Design Vue照片墙a-upload
    echarts多条折线图添加单位
    任意文件下载包含https的图片
    错误:Linux环境jps: command not found
    SqlServer事务
    ADO.NET之连接池
    SqlServer全文索引在项目中的实际应用
  • 原文地址:https://www.cnblogs.com/haonanZhang/p/6505688.html
Copyright © 2011-2022 走看看