js window.settimeout 传参数的方法
很多时候,我们需要在settimeout的函数中传一些参数,但默认的settimeout函数并不支持直接传参数,那怎么办呢。setTimeout 定义和用法:
setTimeout() 方法用于在指定的毫秒数后调用函数或计算表达式。
语法:
setTimeout(code,millisec)
参数:
code (必需):要调用的函数后要执行的 JavaScript 代码串。
millisec(必需):在执行代码前需等待的毫秒数。
提示:
setTimeout() 只执行 code 一次。如果要多次调用,请使用 setInterval() 或者让 code 自身再次调用 setTimeout()。
setTimeOut() 传递参数:
/*
* 先从正常的延时执行说起,以下代码会在2s后弹出true,OK
*/
function st(){
alert(true);
}
setTimeout(st, 2000);
/*
* 下面的代码也会弹出true,但不OK,因为延时没有起作用
*/
function st(arg){
alert(arg);
}
setTimeout(st(true), 2000);
/*
* 解决方法之一,这种方法可以应付参数为字符串型的,对object型就不OK了
*/
function st(arg){
alert(arg);
}
setTimeout(‘st(‘+ true +’)', 2000);
/*
* 解决方法之二,可以利用闭包
*/
function st(arg){
return function(){alert(arg);}
}
var st1 = st(true);
setTimeout(st1, 2000);
/*
* 解决方法之三,可以重载 window.setTimeout 函数,代码转载有修改,这里也有用到闭包的概念
*/
var _st = window.setTimeout;
window.setTimeout = function(fRef, mDelay){
if(typeof fRef == ‘function’){
var argu = Array.prototype.slice.call(arguments,2);
var f = function(){
fRef.apply(null, argu);
};
return _st(f, mDelay);
}
return _st(fRef,mDelay);
}
function st(arg){
alert(arg);
}
setTimeout(st, 2000, true);
页:
[1]