js自定义延迟执行函数

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <style type="text/css">
        .test div{ width: 500px;height: 500px;}
        #aa{ height: auto;}
    </style>
    <script src="Scripts/jquery-1.10.2.min.js"></script>
    <script type="text/javascript">
        (function ($, window) {
            var $window = $(window);
            $.fn.lazyevent = function (options) {
                var elements = this;
                var settings = {
                    threshold: 0,
                    event: "scroll",
                    container: window,
                    skip_invisible: true,
                    fn: null,
                    data: null
                };
                function update() {
                    elements.each(function () {
                        var $this = $(this);
                        if (settings.skip_invisible && !$this.is(":visible")) {
                            return;
                        }
                        if (inviewport(this, settings)) {
                            $this.trigger("fire");
                        }
                    });

                }
                if (options) {
                    $.extend(settings, options);
                }
                var $container = (settings.container === undefined || settings.container === window) ? $window : $(settings.container);

                if (0 === settings.event.indexOf("scroll")) {
                    $container.bind(settings.event, function (event) { return update(); });
                }
                this.each(function () {
                    var self = this;
                    var $self = $(self);
                    self.fired = false;
                    $self.one("fire", function () {
                        if (!this.fired) {
                            if (settings.fn) {
                                settings.fn.call(self, settings.data);
                            }
                            self.fired = true;
                            var temp = $.grep(elements, function (element) { return !element.fired; });
                            elements = $(temp);
                        }
                    });

                    if (0 !== settings.event.indexOf("scroll")) {
                        $self.bind(settings.event, function (event) {
                            if (!self.fired) {
                                $self.trigger("fire");
                            }
                        });
                    }
                });

                $window.bind("resize", function (event) {
                    update();
                });


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

                    if (settings.container === undefined || settings.container === window) {
                        fold = $window.height() + $window.scrollTop();
                    } else {
                        fold = $container.offset().top + $container.height();
                    }
                    return fold <= $(element).offset().top - settings.threshold;
                };

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

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

                    return fold <= $(element).offset().left - settings.threshold;
                };
                var abovethetop = function (element, settings) {
                    var fold;

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

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

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

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

                    return fold >= $(element).offset().left + settings.threshold + $(element).width();
                };
                var inviewport = function (element, settings) {
                    return !abovethetop(element, settings) && !leftofbegin(element, settings) &&
                        !belowthefold(element, settings) && !rightoffold(element, settings);
                };
                update();
                return this;
            };

        })(jQuery, window);
    </script>
    <script type="text/javascript">
        $(function () {
            $("#aa").lazyevent({
                data: "hello word",
                fn: function (data) {
                    var html = $(this).html();
                    alert(data + ":" + html);
                }
            });
        });
    </script>
    
</head>
<body>
    <div style="height: 200px">
    </div>
    <div class="test">
        <div style="background-color: Green" >Green</div>
        <div style="background-color: Lime">Lime</div>
        <div style="background-color: Maroon; display:none">Maroon</div>
        <div style="background-color: Olive">Olive</div>
        <div style="background-color: Red; display: none">Red</div>
        <div style="background-color: ButtonFace">ButtonFace</div>
        <div style="background-color: Aqua">Aqua</div>
        <div style="background-color: AppWorkspace; height:auto;" id="aa" >AppWorkspace</div>
    </div>
</body>
</html>

压缩后的js代码:

    <script type="text/javascript">
        (function (a, c) { var b = a(c); a.fn.lazyevent = function (j) { var g = this; var l = { threshold: 0, event: "scroll", container: c, skip_invisible: true, fn: null, data: null }; function m() { var n = 0; g.each(function () { var o = a(this); if (l.skip_invisible && !o.is(":visible")) { return } if (h(this, l)) { o.trigger("fire") } }) } if (j) { a.extend(l, j) } var d = (l.container === undefined || l.container === c) ? b : a(l.container); if (0 === l.event.indexOf("scroll")) { d.bind(l.event, function (n) { return m() }) } this.each(function () { var o = this; var n = a(o); o.fired = false; n.one("fire", function () { if (!this.fired) { if (l.fn) { l.fn.call(o, l.data) } o.fired = true; var p = a.grep(g, function (q) { return !q.fired }); g = a(p) } }); if (0 !== l.event.indexOf("scroll")) { n.bind(l.event, function (p) { if (!o.fired) { n.trigger("fire") } }) } }); b.bind("resize", function (n) { m() }); var f = function (n, p) { var o; if (p.container === undefined || p.container === c) { o = b.height() + b.scrollTop() } else { o = d.offset().top + d.height() } return o <= a(n).offset().top - p.threshold }; var k = function (n, p) { var o; if (p.container === undefined || p.container === c) { o = b.width() + b.scrollLeft() } else { o = d.offset().left + d.width() } return o <= a(n).offset().left - p.threshold }; var e = function (n, p) { var o; if (p.container === undefined || p.container === c) { o = b.scrollTop() } else { o = d.offset().top } return o >= a(n).offset().top + p.threshold + a(n).height() }; var i = function (n, p) { var o; if (p.container === undefined || p.container === c) { o = b.scrollLeft() } else { o = d.offset().left } return o >= a(n).offset().left + p.threshold + a(n).width() }; var h = function (n, o) { return !e(n, o) && !i(n, o) && !f(n, o) && !k(n, o) }; m(); return this } })(jQuery, window);
    </script>

 

posted @ 2014-12-30 15:20  学亮  阅读(1389)  评论(0编辑  收藏  举报