电脑技术学习

JavaScript如何给window.setInterval的函数传递参数

dn001

众所周知,调用window.setInterval(funcname,time)时,funcname要么直接放置函数体,要么放置函数的名字,比如


程序代码
function test(){
alert("");
}

window.setInterval(test,1000);
//window.setInterval("test",1000);


不过,如果要想给test函数传递参数就不好办了。实际上,通过一个匿名函数,就可以实现给函数传递参数了,比如


程序代码
function test(username){
alert(username);
}

window.setInterval(function(){
test.apply(this,"comDeng");
},1000);


这样以来,就将"comDeng"传递给test函数了。如果要做一个通用的处理方法的话,就可以写这样一个函数来实现。


程序代码
function test(username){
alert(username);
}

function bindInterval(funcName){
var args=[];
for(var i=1;i<arguments.length;i++){
args.push(arguments[i]);
}
return function(){
funcName.apply(this,args);
}
}

window.setInterval(bindInterval(test,"comDeng"),1000);


像这种调用方法,看起来还是蛮复杂的,不妨再做一些简化:


程序代码
function test(username){
alert(username);
}

function JInterval(funcName,time){
var args=[];
for(var i=2;i<arguments.length;i++){
args.push(arguments[i]);
}
return window.setInterval(function(){
funcName.apply(this,args);
},time);
}
JInterval(test,2000,"comDeng");


这样以来的话,比原来可简洁多了!