jQuery中出现意外的回调行为

时间:2013-10-07 14:59:02

标签: javascript jquery callback

我希望以下代码运行如下: 1)迭代for循环直到完成。 2)执行回调函数

相反,它在每次迭代后执行回调。这是范围问题吗?我是否误解了回调的控制流程?

function flipPages(direction,n,duration,callback){
    for(i=0;i<n;i++){
        setTimeout(function() { $('#flipbook').turn(direction);}, ((i+1) * duration));
    }
    callback;
}

flipPages("next",4,1000,flipPages("previous",4,2000));

1 个答案:

答案 0 :(得分:1)

除了所有这些相关评论之外,我想你想做这样的事情:

function flipPages(direction, n, duration){
    for(var i = 0, l = n; i < n; i++){
        setTimeout(function() { 
            $('#flipbook').turn(direction);
            if (!(--n)) {
                flipPages({
                    // direction switch
                    next: "previous",
                    previous: "next"
                }[direction], n, duration);
            }
        }, ((i + 1) * duration));
    }
}

flipPages("next", 4, 1000);

更新:无需使用回调,直接使用flipPages