2015-09-16 3 views
0

у кого-то есть идея о ленивой загрузке. Кажется, что это не работает на моей странице.ленивый эффект загрузки, похоже, не работает на моей странице

Я сделал что-то не так?



вот моя страница ->http://500milligrammes.com/fmzz/final/test.html


вот мой HTML часть:

<img class="lazy img-responsive" src="...jpg" data-original="...jpg" alt=""/> 


вот мой JS часть:

$(function() { 
$("img.lazy").lazyload({ 
effect : "fadeIn" 
}); 



вот моя страница jquery.lazyload.js:

/*! 
    * Lazy Load - jQuery plugin for lazy loading images 
    * 
    * Copyright (c) 2007-2015 Mika Tuupola 
    * 
    * Licensed under the MIT license: 
    * http://www.opensource.org/licenses/mit-license.php 
    * 
    * Project home: 
    * http://www.appelsiini.net/projects/lazyload 
    * 
    * Version: 1.9.5 
    * 
*/ 

(function($, window, document, undefined) { 
var $window = $(window); 

$.fn.lazyload = function(options) { 
    var elements = this; 
    var $container; 
    var settings = { 
     threshold  : 0, 
     failure_limit : 0, 
     event   : "scroll", 
     effect   : "show", 
     container  : window, 
     data_attribute : "original", 
     skip_invisible : false, 
     appear   : null, 
     load   : null, 
     placeholder  : "" 
    }; 

    function update() { 
     var counter = 0; 

     elements.each(function() { 
      var $this = $(this); 
      if (settings.skip_invisible && !$this.is(":visible")) { 
       return; 
      } 
      if ($.abovethetop(this, settings) || 
       $.leftofbegin(this, settings)) { 
        /* Nothing. */ 
      } else if (!$.belowthefold(this, settings) && 
       !$.rightoffold(this, settings)) { 
        $this.trigger("appear"); 
        /* if we found an image we'll load, reset the counter */ 
        counter = 0; 
      } else { 
       if (++counter > settings.failure_limit) { 
        return false; 
       } 
      } 
     }); 

    } 

    if(options) { 
     /* Maintain BC for a couple of versions. */ 
     if (undefined !== options.failurelimit) { 
      options.failure_limit = options.failurelimit; 
      delete options.failurelimit; 
     } 
     if (undefined !== options.effectspeed) { 
      options.effect_speed = options.effectspeed; 
      delete options.effectspeed; 
     } 

     $.extend(settings, options); 
    } 

    /* Cache container as jQuery as object. */ 
    $container = (settings.container === undefined || 
        settings.container === window) ? $window : $(settings.container); 

    /* Fire one scroll event per scroll. Not one scroll event per image. */ 
    if (0 === settings.event.indexOf("scroll")) { 
     $container.bind(settings.event, function() { 
      return update(); 
     }); 
    } 

    this.each(function() { 
     var self = this; 
     var $self = $(self); 

     self.loaded = false; 

     /* If no src attribute given use data:uri. */ 
     if ($self.attr("src") === undefined || $self.attr("src") === false) { 
      if ($self.is("img")) { 
       $self.attr("src", settings.placeholder); 
      } 
     } 

     /* When appear is triggered load original image. */ 
     $self.one("appear", function() { 
      if (!this.loaded) { 
       if (settings.appear) { 
        var elements_left = elements.length; 
        settings.appear.call(self, elements_left, settings); 
       } 
       $("<img />") 
        .bind("load", function() { 

         var original = $self.attr("data-" + settings.data_attribute); 
         $self.hide(); 
         if ($self.is("img")) { 
          $self.attr("src", original); 
         } else { 
          $self.css("background-image", "url('" + original + "')"); 
         } 
         $self[settings.effect](settings.effect_speed); 

         self.loaded = true; 

         /* Remove image from array so it is not looped next time. */ 
         var temp = $.grep(elements, function(element) { 
          return !element.loaded; 
         }); 
         elements = $(temp); 

         if (settings.load) { 
          var elements_left = elements.length; 
          settings.load.call(self, elements_left, settings); 
         } 
        }) 
        .attr("src", $self.attr("data-" + settings.data_attribute)); 
      } 
     }); 

     /* When wanted event is triggered load original image */ 
     /* by triggering appear.        */ 
     if (0 !== settings.event.indexOf("scroll")) { 
      $self.bind(settings.event, function() { 
       if (!self.loaded) { 
        $self.trigger("appear"); 
       } 
      }); 
     } 
    }); 

    /* Check if something appears when window is resized. */ 
    $window.bind("resize", function() { 
     update(); 
    }); 

    /* With IOS5 force loading images when navigating with back button. */ 
    /* Non optimal workaround. */ 
    if ((/(?:iphone|ipod|ipad).*os 5/gi).test(navigator.appVersion)) { 
     $window.bind("pageshow", function(event) { 
      if (event.originalEvent && event.originalEvent.persisted) { 
       elements.each(function() { 
        $(this).trigger("appear"); 
       }); 
      } 
     }); 
    } 

    /* Force initial check if images should appear. */ 
    $(document).ready(function() { 
     update(); 
    }); 

    return this; 
}; 

/* Convenience methods in jQuery namespace.   */ 
/* Use as $.belowthefold(element, {threshold : 100, container : window}) */ 

$.belowthefold = function(element, settings) { 
    var fold; 

    if (settings.container === undefined || settings.container === window) { 
     fold = (window.innerHeight ? window.innerHeight : $window.height()) + $window.scrollTop(); 
    } else { 
     fold = $(settings.container).offset().top + $(settings.container).height(); 
    } 

    return fold <= $(element).offset().top - settings.threshold; 
}; 

$.rightoffold = function(element, settings) { 
    var fold; 

    if (settings.container === undefined || settings.container === window) { 
     fold = $window.width() + $window.scrollLeft(); 
    } else { 
     fold = $(settings.container).offset().left + $(settings.container).width(); 
    } 

    return fold <= $(element).offset().left - settings.threshold; 
}; 

$.abovethetop = function(element, settings) { 
    var fold; 

    if (settings.container === undefined || settings.container === window) { 
     fold = $window.scrollTop(); 
    } else { 
     fold = $(settings.container).offset().top; 
    } 

    return fold >= $(element).offset().top + settings.threshold + $(element).height(); 
}; 

$.leftofbegin = function(element, settings) { 
    var fold; 

    if (settings.container === undefined || settings.container === window) { 
     fold = $window.scrollLeft(); 
    } else { 
     fold = $(settings.container).offset().left; 
    } 

    return fold >= $(element).offset().left + settings.threshold + $(element).width(); 
}; 

$.inviewport = function(element, settings) { 
    return !$.rightoffold(element, settings) && !$.leftofbegin(element, settings) && 
      !$.belowthefold(element, settings) && !$.abovethetop(element, settings); 
}; 

/* Custom selectors for your convenience. */ 
/* Use as $("img:below-the-fold").something() or */ 
/* $("img").filter(":below-the-fold").something() which is faster */ 

$.extend($.expr[":"], { 
    "below-the-fold" : function(a) { return $.belowthefold(a, {threshold : 0}); }, 
    "above-the-top" : function(a) { return !$.belowthefold(a, {threshold : 0}); }, 
    "right-of-screen": function(a) { return $.rightoffold(a, {threshold : 0}); }, 
    "left-of-screen" : function(a) { return !$.rightoffold(a, {threshold : 0}); }, 
    "in-viewport" : function(a) { return $.inviewport(a, {threshold : 0}); }, 
    /* Maintain BC for couple of versions. */ 
    "above-the-fold" : function(a) { return !$.belowthefold(a, {threshold : 0}); }, 
    "right-of-fold" : function(a) { return $.rightoffold(a, {threshold : 0}); }, 
    "left-of-fold" : function(a) { return !$.rightoffold(a, {threshold : 0}); } 
}); 

})(jQuery, window, document); 

ответ

0
  • Я бы рекомендовал не использовать метку img в качестве заполнителя. Атрибут src равен mandatory, поэтому вы создаете недействительный HTML.
  • И я также wouldn't use jQuery за такую ​​крошечную функциональность.

Следующие justlazy plugin предоставляет действительный HTML без jQuery.

1. Определить заполнитель

<span data-src="default/image" data-alt="some alt text" 
 
     class="justlazy-placeholder"> 
 
</span>

2. Регистрация отложенной загрузки

$(function() { 
 
    Justlazy.registerLazyLoadByClass("justlazy-placeholder"); 
 
});

+0

хорошая идея тоже; D –

+0

Я забыл добавить ссылку на библиотеку;) Добавлено –

+0

Я видел;) yep !!! –

1

Первый выпуск:

Вы должны закрыть готовую функцию.

$(function() { 
    $("img.lazy").lazyload({ 
    effect : "fadeIn" 
    }); 
}); 

Второй выпуск:

Вот использование о том, как реализовать ленивые нагрузки на сайте:

<img class="lazy" data-original="img/example.jpg" width="640" height="480"> 

Теперь с этим вы должны хранить его в атрибуте данных (само изображение). То, что вы делаете, - это вызов изображения в src, а также в атрибуте data. Теперь, когда страница загружается, на самом деле начинается процесс загрузки изображений с помощью src, и тогда происходит ленивая загрузка.

+0

Когда вы пытаетесь, это работает, я думаю, ничего не изменится? –

+0

@fatyfatoumata отредактировал мое сообщение. Если вы хотите, чтобы живой пример редактировался, используйте codepen или jsfiddle и используйте онлайн-ресурсы, например. lazyload cdn и место.это изображения – jagmitg

+0

ОК, я сделаю это !! спасибо;) –

 Смежные вопросы

  • Нет связанных вопросов^_^