3

我想禁用点击功能,直到其中的每个代码;初始化并完成。

我阅读了这些文章并尝试了他们所说的但无法实现: event.preventDefault() vs. return false + 在 jQuery 中删除事件处理程序的最佳方法? + jQuery - 禁用单击,直到所有链接的动画都完成

我为这个问题准备了简单的例子:

这是演示

html

<div class="ele">1</div>
<div class="ele">2</div>
<div class="ele">3</div>

​</p>

jQuery

$('.ele').click(function() {

    if ( !$('.ele').is(':animated') ) {//this works too but;
                         //is:animate duration returns = 2000 but need to be 4000
        $('.ele').stop().animate({'top':'0px'},2000);
        $(this).stop().animate({'top':'100px'},4000);
    } 
    return false;
});
​
4

2 回答 2

5

使用 on() 和 off() 打开/关闭点击功能:

$('.ele').on('click', animateEle);

function animateEle(e) {
    $('.ele').stop().animate({'top':'0px'},2000);
    $(e.target).off('click').stop().animate({'top':'100px'},4000, function() {
        $(e.target).on('click', animateEle);
    });
}​

示范

于 2012-07-01T16:00:46.720 回答
0

你可以试试这个:

var exec_a1 = true, exec_a2 = true;
$('.ele').click(function() {
    if (exec_a1 && exec_a2) {
        exec_a1 = false;
        exec_a2 = false;

        $('.ele').stop().animate({'top': '0px'}, 2000, function() {
            exec_a1 = true;
        });
        $(this).stop().animate({'top': '100px'}, 4000, function() {
            exec_a2 = true;
        });
    }
    return false;
});
于 2012-07-01T15:49:26.080 回答