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

    1.引入js jquery.lazyload.js(如下)

    /*
     * 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);
    

    2.初始化页面

    $(function(){
    	$(".body_main img").lazyload({
            effect : "fadeIn",
            failurelimit : 5
    
        });
    });




  • 相关阅读:
    c 中有关打印*,字符的题目集
    c 求两个整数的最大公约数和最小公倍数
    cygwin中vim的使用方法
    window下如何搭建linux环境
    ORA-00923: 未找到要求的 FROM 关键字
    c# datagridviewcomboboxcell值无效的解决办法
    sql substring charindex
    C# 中datagridview行里面有三个cheeckbox,要控制成三选一。
    程序中使用事务来管理sql语句的执行,执行失败时,可以达到回滚的要求。
    WinForm界面中快捷键设置
  • 原文地址:https://www.cnblogs.com/dulinan/p/12033065.html
Copyright © 2011-2022 走看看