-1

我有参数简化为的乘法函数:

    function f1(p1,p2){
        alert('Function one is P1:'+p1+' P2:'+p2);        
    }
    function f2(p1,p2){
        alert('Function two is P1:'+p1+' P2:'+p2);
    }

我需要触发这些是一个有延迟的序列。然而,我发现 jQuery 不喜欢使用参数运行函数。我已经尝试过 .click 功能。

$.delay(1000).click(f1('One',false)).delay(1000).click(f2('One',false));

但是延迟使得点击功能不起作用......

4

4 回答 4

9

我只会使用一个简单的超时:

f1("one", false);
setTimeout(function() { f2("one", false); }, 1000);
于 2012-08-02T16:42:51.320 回答
0
$.delay(1000).click(function(){f1('One',false);}).delay(1000).click(function(){f2('One',false);});

不知道点击是为了什么......

于 2012-08-02T16:45:05.850 回答
0

如果您想延迟函数调用,那么更简单的方法是使用 setTimeout()。

eg: // 在嵌套的 setTimeout 中调用它以实现顺序延迟执行 setTimeout(function(){

 f1('One',false);
  setTimeout(function(){
    f1('One',false)
  },300)
},300)
于 2012-08-02T16:46:09.177 回答
0
function fn1()
{
    alert(1);
}
function fn2()
{
    alert(2);
}
var arr=[fn1,fn2];
var len=arr.length;
var time=1000;
for(var k=0;k<len;k++)
{
    (function(k)
    {
        setTimeout(arr[k],time);
    }(k))
    time=time*2;
}

它在延迟 1 秒后执行! 演示

于 2012-08-02T16:55:36.260 回答