jquery.lazyload.js 图片延迟加载

openkk 13年前

 jQuery页面图片伴随滚动条逐渐显示 
根据实际应用可以进行相应的修改

// 天涯版  (function(jQuery) {        jQuery.fn.lazyload = function(options) {          var settings = {              threshold    : 0,              failurelimit : 0,              event        : "scroll",              effect       : "show",              container    : window          };                            if(options) {              jQuery.extend(settings, options);          }            /* Fire one scroll event per scroll. Not one scroll event per image. */          var elements = this;          if ("scroll" == settings.event) {              jQuery(settings.container).bind("scroll", function(event) {                                    var counter = 0;                  elements.each(function() {                      if (jQuery.abovethetop(this, settings)) {                              /* Nothing. */                      } else if (!jQuery.belowthefold(this, settings)) {                              jQuery(this).trigger("appear");                      } else {                          if (counter++ > settings.failurelimit) {                              return false;                          }                      }                  });                  /* Remove image from array so it is not looped next time. */                  var temp = jQuery.grep(elements, function(element) {                      return !element.loaded;                  });                  elements = jQuery(temp);              });          }                    this.each(function() {              var self = this;                            /* Save original only if it is not defined in HTML. */              if (undefined != jQuery(self).attr("original")){      self.loaded = false;        /* When appear is triggered load original image. */      jQuery(self).one("appear", function() {       if (!this.loaded) {        jQuery("<img />")         .bind("load", function() {          jQuery(self)           .hide()           .removeAttr("height")           .attr("src", jQuery(self).attr("original"))           [settings.effect](settings.effectspeed);          self.loaded = true;         })         .attr("src", jQuery(self).attr("original"));       };      });     }          });                    /* Force initial check if images should appear. */          jQuery(settings.container).trigger(settings.event);                    return this;      };        /* Convenience methods in jQuery namespace.           */      /* Use as  jQuery.belowthefold(element, {threshold : 100, container : window}) */      function checkshow(){          }         jQuery.belowthefold = function(element, settings) {          if (settings.container === undefined || settings.container === window) {              var fold = jQuery(window).height()*2 + jQuery(window).scrollTop();          } else {              var fold = jQuery(settings.container).offset().top + jQuery(settings.container).height()*2;          }            return fold <= jQuery(element).offset().top - settings.threshold;        };         jQuery.abovethetop = function(element, settings) {          if (settings.container === undefined || settings.container === window) {              var fold = jQuery(window).scrollTop();          } else {              var fold = jQuery(settings.container).offset().top;          }          return fold >= jQuery(element).offset().top + settings.threshold  + jQuery(element).height();      };      /* Custom selectors for your convenience.   */      /* Use as jQuery("img:below-the-fold").something() */        jQuery.extend(jQuery.expr[':'], {          "below-the-fold" : "jQuery.belowthefold(a, {threshold : 0, container: window})",          "above-the-fold" : "!jQuery.belowthefold(a, {threshold : 0, container: window})"      });        })(jQuery);      jQuery("#pContentDiv .post img[original]").lazyload({   effect:"fadeIn"  });