如何防止回调多次触发?

时间:2012-09-13 21:16:55

标签: javascript jquery callback jquery-animate

我在这里看到了几个问题,(包括使用when / promise解决方案),但它们似乎没有用。基本上我一次动画多个元素,并在回调中调用一个函数,但函数被多次调用 - 对于每个被动画化的元素......这是我的代码:

OBJCollection.css({
    'width': '0em',
    'height': '0em'
}).animate({
    'width': Screens.ImageW / 16 + 'em',
    'height': Screens.ImageH / 16 + 'em'
}, {
    duration: Screens.currentImageParent.data('LightboxFadeSpeedIn'),
    queue: false,
    step: function (now, fx) {
        componentScaler();
    },
    complete: function () {
        $Content.show('fade', Screens.currentImageParent.data('ContentFadeSpeedIn'));
        //calling function here
    }
});

我试过了:

if (!OBJCollection.is(':animated')) { ... call function }

哪个不起作用。我也尝试过使用when的解决方案,但这似乎抛弃了我的函数调用(根据OBJCollection的最终动画大小定位其他元素)。我不确定(因为这是我第一次使用/ promise),但是在第一个项目完成动画并忽略所有其他项目之后它是否会触发一次回调?看起来这就是它正在做的事情,但我正在寻找一个解决方案,当所有项目完成动画时触发回调....

有什么想法吗?

1 个答案:

答案 0 :(得分:5)

使用承诺对象。

OBJCollection.css({
    'width': '0em',
    'height': '0em'
}).animate({
    'width': Screens.ImageW / 16 + 'em',
    'height': Screens.ImageH / 16 + 'em'
}, {
    duration: Screens.currentImageParent.data('LightboxFadeSpeedIn'),
    queue: false,
    step: function(now, fx) {
        componentScaler();
    }
}).promise().done(function() {
    $Content.show('fade', Screens.currentImageParent.data('ContentFadeSpeedIn'));
    //calling function here
});​