miércoles, 5 de junio de 2013

Como Añadir JQuery Lazy Load a Tu Blog

Leave a Comment
Como Añadir JQuery Lazy Load a Tu Blog
Este artículo le explicará cómo agregar el Plugin de JQuery Lazy Load para tu blog de Blogger o cualquier otro sitio web facilmente.Si tienes un blog o página web que contiene muchas imágenes, este super truco será muy útil para ti.Este puede reducir el tiempo de carga de la página de su sitio.Tu puede ver la página de prueba para ver el resultado.

     Lazy loader es un plugin de jQuery escrito en JavaScript. Se retrasa la carga de imágenes  a lo largo la de páginas web. Imágenes fuera del visor (parte visible de la página web) no será cargada antes solo cuando el usuario se desplaza sobre estas. Con carga perezosa en largas páginas web que contengan muchas imágenes de gran tamaño hace que la carga de la página sea más rápidamente. Navegador estará preparado después de cargar imágenes visibles. En algunos casos, también puede ayudar a reducir la carga del servidor.


Para agregar JQuery Lazy Load Plugin para tu blog de Blogger o cualquier otro sitio web siga los pasos que se indican a continuación:


1.Inicie sesión en blogger -> diseño--> Edición de HTML

2.Desplácese hasta donde se ve </ head>.

3.Copia el siguiente código y pégalo justo antes de la etiqueta </ head>.

<script charset='utf-8' src='http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js' type='text/javascript'/> <script type='text/javascript'> //<![CDATA[ /* * Lazy Load - jQuery plugin for lazy loading images * * Copyright (c) 2007-2009 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.5.0 * */ (function($) { $.fn.lazyload = function(options) { var settings = { threshold : 0, failurelimit : 0, event : "scroll", effect : "show", container : window }; if(options) { $.extend(settings, options); } /* Fire one scroll event per scroll. Not one scroll event per image. */ var elements = this; if ("scroll" == settings.event) { $(settings.container).bind("scroll", function(event) { var counter = 0; elements.each(function() { if ($.abovethetop(this, settings) || $.leftofbegin(this, settings)) { /* Nothing. */ } else if (!$.belowthefold(this, settings) && !$.rightoffold(this, settings)) { $(this).trigger("appear"); } else { if (counter++ > settings.failurelimit) { return false; } } }); /* Remove image from array so it is not looped next time. */ var temp = $.grep(elements, function(element) { return !element.loaded; }); elements = $(temp); }); } this.each(function() { var self = this; /* Save original only if it is not defined in HTML. */ if (undefined == $(self).attr("original")) { $(self).attr("original", $(self).attr("src")); } if ("scroll" != settings.event || undefined == $(self).attr("src") || settings.placeholder == $(self).attr("src") || ($.abovethetop(self, settings) || $.leftofbegin(self, settings) || $.belowthefold(self, settings) || $.rightoffold(self, settings) )) { if (settings.placeholder) { $(self).attr("src", settings.placeholder); } else { $(self).removeAttr("src"); } self.loaded = false; } else { self.loaded = true; } /* When appear is triggered load original image. */ $(self).one("appear", function() { if (!this.loaded) { $("<img />") .bind("load", function() { $(self) .hide() .attr("src", $(self).attr("original")) [settings.effect](settings.effectspeed); self.loaded = true; }) .attr("src", $(self).attr("original")); }; }); /* When wanted event is triggered load original image */ /* by triggering appear. */ if ("scroll" != settings.event) { $(self).bind(settings.event, function(event) { if (!self.loaded) { $(self).trigger("appear"); } }); } }); /* Force initial check if images should appear. */ $(settings.container).trigger(settings.event); return this; }; /* Convenience methods in jQuery namespace. */ /* Use as $.belowthefold(element, {threshold : 100, container : window}) */ $.belowthefold = function(element, settings) { if (settings.container === undefined || settings.container === window) { var fold = $(window).height() + $(window).scrollTop(); } else { var fold = $(settings.container).offset().top + $(settings.container).height(); } return fold <= $(element).offset().top - settings.threshold; }; $.rightoffold = function(element, settings) { if (settings.container === undefined || settings.container === window) { var fold = $(window).width() + $(window).scrollLeft(); } else { var fold = $(settings.container).offset().left + $(settings.container).width(); } return fold <= $(element).offset().left - settings.threshold; }; $.abovethetop = function(element, settings) { if (settings.container === undefined || settings.container === window) { var fold = $(window).scrollTop(); } else { var fold = $(settings.container).offset().top; } return fold >= $(element).offset().top + settings.threshold + $(element).height(); }; $.leftofbegin = function(element, settings) { if (settings.container === undefined || settings.container === window) { var fold = $(window).scrollLeft(); } else { var fold = $(settings.container).offset().left; } return fold >= $(element).offset().left + settings.threshold + $(element).width(); }; /* Custom selectors for your convenience. */ /* Use as $("img:below-the-fold").something() */ $.extend($.expr[':'], { "below-the-fold" : "$.belowthefold(a, {threshold : 0, container: window})", "above-the-fold" : "!$.belowthefold(a, {threshold : 0, container: window})", "right-of-fold" : "$.rightoffold(a, {threshold : 0, container: window})", "left-of-fold" : "!$.rightoffold(a, {threshold : 0, container: window})" }); })(jQuery); //]]> </script> <script charset='utf-8' type='text/javascript'> $(function() { $(&quot;img&quot;).lazyload({placeholder : &quot;https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEio3aPiSOqv2LYzBDhNR_ZpfHsozTNHlrcBDbA9V8nDsFSwMUssG4k7UyX8ks6Z20HoDjNQWzBN76uV6LaTUZ8rOvBp8SxyTPR69-WgyOO1TfvyRkEnUCKNmGTtXS0XgpV2BMkQYUIWWq8/s1600/grey.gif&quot;,threshold : 200}); }); </script>

4.Ahora guardar la plantilla y Listo.Recarga su sitio para ver el resultado.
Enhanced by Zemanta
If You Enjoyed This, Take 5 Seconds To Share It

0 comentarios:

Publicar un comentario