看來的能力已經被添加到一些瀏覽器傳遞參數的setTimeout:
語法:setTimeout (function (p1,p2) {},1000,p1,p2);
(只要你想添加儘可能多的PARAMS)
如果你想確保它的工作原理到處都可以使用附帶的代碼。
注:如果你想在安裝後立即設置超時,最好使用回調參數,做它在那裏
例如
installSwizzledTimeout(function(param1,param2){
setTimeout(myFunc,200,param1,param2);},param1,param2);
}
這是因爲它使用一個技巧來檢測是否需要,通過設置非常短的超時時間並計算參數。
window.swizzledSetTimeout = function (fn, ms) {
if (arguments.length === 2) {
//console.log("Bypassing swizzledSetTimeout");
return window.originalSetTimeout(fn, ms);
} else {
var args = [];
for (i = 2; i < arguments.length; i++) {
args.push(arguments[i])
};
//console.log("Setting swizzledSetTimeout for function (",args,") {...} in ",ms," msec");
var retval = window.originalSetTimeout(function() {
//console.log("Invoking swizzledSetTimeout for function (",args,") {...}");
fn.apply(null, args);
}, ms);
return retval;
}
}
function installSwizzledTimeout(cb) {
var args = [];
for (i = 1; i < arguments.length; i++) {
args.push(arguments[i])
};
setTimeout(function (arg) {
//console.log("arguments.length:",arguments.length,window.setTimeout.toString());
if (arguments.length == 0) {
function doInstall() {
//console.log("Installing new setTimeout");
window.originalSetTimeout = window.setTimeout;
window.setTimeout = function setTimeout() {
return window.swizzledSetTimeout.apply(null, arguments);
};
if (cb) {
cb.apply(null, args);
};
}
if (window.setTimeout.toString().indexOf("swizzledSetTimeout") < 0) {
doInstall();
}
} else {
//console.log("existing set time supports arguments ");
if (cb) {
cb.apply(null, args);
};
}
}, 0, 1, 2, 3, 4);
}
需要注意的是,當調用函數時,傳遞給'makeTimeout'的值將是'sp.name'的值,可能與調用'setTImeout'時的值不同。 – RobG
根據http://kangax.github.io/es5-compat-table/#Function.prototype.bind,主要瀏覽器現在支持綁定。 –
正如RobG所說,爲了使這個工作100%正常工作,您需要使用關閉 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Closures 在超時過期時,值'sp.name'可能已經改變。 – ikromm