知识 分享 互助 懒人建站

    懒人建站专注于网页素材下载,提供网站模板、网页设计、ps素材、图片素材等,服务于【个人站长】【网页设计师】和【web开发从业者】的代码素材与设计素材网站。

    懒人建站提供网页素材下载、网站模板
    知识 分享 互助!

    按需要延时加载图片和ajax方式加载页面jQuery插件

    作者:佳明妈 来源:jquery 特效 2012-02-25 人气:
    有时候页面上的图片非常多,比如一个大量图片的营销型单页面,如果不采取一些延时按需要加载图片一次性读入图片,页面会加载很长时间,用户体验大大的不好。 这个jquery插件实现

    有时候页面上的图片非常多,比如一个大量图片的营销型单页面,如果不采取一些延时按需要加载图片一次性读入图片,页面会加载很长时间,用户体验大大的不好。

    这个jquery插件实现按需要延时加载图片和ajax方式加载页面,jquery代码短小精悍。灰常给力,给力就到懒人建站点两下广告,表示支持工作。

    <script type="text/javascript" src="http://lib.sinaapp.com/js/jquery/1.4.1/jquery.min.js"></script>
    <script type="text/javascript" src="jq.scrollLoading.js"></script>
    <script>
    $(function() {
        $(".scrollLoading").scrollLoading();
    });
    </script>


    按需要延时加载图片和ajax方式加载页面jQuery插件代码:
    (function($) {
        $.fn.scrollLoading = function(options) {
            var defaults = {
                attr: "data-url"    
            };
            var params = $.extend({}, defaults, options || {});
            params.cache = [];
            $(this).each(function() {
                var node = this.nodeName.toLowerCase(), url = $(this).attr(params["attr"]);
                if (!url) { return; }
                //重组
                var data = {
                    obj: $(this),
                    tag: node,
                    url: url
                };
                params.cache.push(data);
            });
            
            //动态显示数据
            var loading = function() {
                var st = $(window).scrollTop(), sth = st + $(window).height();
                $.each(params.cache, function(i, data) {
                    var o = data.obj, tag = data.tag, url = data.url;
                    if (o) {
                        post = o.offset().top; posb = post + o.height();
                        if ((post > st && post < sth) || (posb > st && posb < sth)) {
                            //在浏览器窗口内
                            if (tag === "img") {
                                //图片,改变src
                                o.attr("src", url);    
                            } else {
                                o.load(url);
                            }    
                            data.obj = null;        
                        }
                    }
                });        
                return false;    
            };
            
            //事件触发
            //加载完毕即执行
            loading();
            //滚动执行
            $(window).bind("scroll", loading);
        };
    })(jQuery);

    ↓ 查看全文

    按需要延时加载图片和ajax方式加载页面jQuery插件由懒人建站收集整理,您可以自由传播,请主动带上本文链接

    懒人建站就是免费分享,觉得有用就多来支持一下,没有能帮到您,懒人也只能表示遗憾,希望有一天能帮到您。

    按需要延时加载图片和ajax方式加载页面jQuery插件-最新评论