1

指定されたすべての div を 1 つずつフェードインする効果を達成しようとしています。私はこの関数を書きました:

jQuery:

(function($) {
    $.fn.fadeAll = function (options) {
        options = $.extend({}, $.fn.fadeAll.defaults, options || {});

        var loops = $(this).length;

        return $(this).each(function (i, obj) {            
            $(obj).fadeTo(options.speed, options.opacity);

            if (i++ >= loops) {
                if (typeof (options.onComplete) == 'function') {
                    options.onComplete.call();
                }
            }
            //alert($(obj).html());
        });
    };

    $.fn.fadeAll.defaults = {
        speed:      300,
        opacity:    1,
        onComplete: null
    };
})(jQuery);

各ループでは、すべてのオブジェクトをループするのを監視するアラートを配置しました。このように呼び出すと、正常に機能します

関数の呼び出し:

$('.nav-div').fadeAll({
    onComplete:
        function () {
            alert('done');
        }
    });

HTML:

</head>
<body>
    <section id="global-wrapper">
        <section id="load-wrapper">
            <div>
                <h1>LOADING</h1>
                <h3 id="load-percent"></h3>
            </div>
        </section>
        <section id="main-wrapper">
            <h1>TITLE</h1>
            <nav>
                <div class="nav-div">MENU ITEM 1</div>
                <div class="nav-div">MENU ITEM 2</div>
                <div class="nav-div">MENU ITEM 3</div>
                <div class="nav-div">MENU ITEM 4</div>
            </nav>
        </section>
    </section>
</body>
</html>

CSS:

body {
    background: #000;
    color: #eee;
}

#global-wrapper {
    min-height: 2000px;
}

#load-wrapper {
    margin: 0 auto;
    width: 65%;
    height: 400px;
    position: absolute;
    top: 200px;
    left: 17.5%;
}
    #load-wrapper > div {
        background: url('/Content/Images/loading.gif') center center no-repeat;
        width: 100%;
        height: 300px;
    }
        #load-wrapper > div > h1 {
            font-family: 'IM Fell DW Pica', serif;
            font-size: 30px;
            color: #eee;
            text-align: center;
            line-height: 100px;
        }
        #load-wrapper > div > h3 {
            font-family: 'IM Fell DW Pica', serif;
            font-size: 30px;
            color: #eee;
            text-align: center;
            line-height: 100px;
            margin-top: 100px;
        }

#main-wrapper {
    margin: 0 auto;
    width: 1024px;
}
    #main-wrapper > h1 {
        opacity: 0;
        font-size: 30px;
        font-family: 'IM Fell DW Pica', serif;
    }
    #main-wrapper > nav > div {
        opacity: 0;
        float: left;
        margin-right: 20px;
        font-family: Gruppo;
        font-size: 18px;
        cursor: pointer;
    }

私のコールバックはすべて期待どおりに機能しており、すべてが起動しています。ただし、私の問題は、ループを通過している間、実際にはfadeTo部分を実行していないことです。むしろ、ループを通過し終わるまで待ってから、一度にすべてフェードインします。

ここで私が間違っていることを誰かが指摘できますか? 欠けているのは単純なものか、欠けているjQuery/jsの機能の一部だと確信しています。どんな助けでも大歓迎です!

4

1 に答える 1