[英]Difference between foo() and function() { foo(); }
使用匿名函数包装函数有什么好处吗? 我的意思是一个特例:
function asyncFuntion(callback) {
setTimeout(callback, 6000);
};
asyncFuntion(function() {
console.log('Calling after 6 s.');
});
以及包装功能:
function asyncFuntion(callback) {
setTimeout(function() {
callback();
}, 6000);
};
asyncFuntion(function() {
console.log('Calling after 6 s.');
});
在这两种情况下输出都是相同的。 那有什么区别吗? 第二个版本是我发现的学习js。 我知道当我们需要闭包时这样的表格很有用但是在这里?
第二种形式允许您将参数传递给callback
,而第一种形式则不允许。
// 1st form
setTimeout(callback("This doesn't work as you might expect"), 6000);
// 2nd form
setTimeout(function() {
callback("This works");
}, 6000);
如果你没有传递参数,那么包装函数没有任何优势。
Function.prototype.bind
可以帮助我们使用第一种形式:
setTimeout(callback.bind(this, "This works fine too"), 6000); // Even with Richard JP Le Guen's example by specifying the thisObj setTimeout(customObj.alert.bind(customObj), 6000);
但是,您需要将此方法提供给不支持该事件的浏览器(即Opera,Safari和IE 8,7,6)。 可以在MDN文档页面上找到用于填充方法的代码。
在匿名函数中包装函数可以避免使用this
关键字的复杂性。 ( 在quirksmode上阅读它们 )
例如:
function CustomObject() {
this.msg = "Hello world from my custom object";
this.alert = function() {
alert(this.msg);
};
}
var customObj = new CustomObject();
setTimeout(customObj.alert, 1000); // the alert message says `undefined`
setTimeout(function() {
customObj.alert();
}, 2000); // the alert message says "Hello world from my custom object"
在匿名函数中包装函数也是在JavaScript中使用闭包的关键:
var arr = ['a','b','c','d','e'];
// will always alert undefined
for(var i=0; i<arr.length; i++) {
setTimeout(function() {
console.log(arr[i]);
}, 1000*i);
}
// outputs the values of `arr`
for(var j=0; j<arr.length; j++) {
setTimeout((function(indx) {
return function() {
console.log(arr[indx]);
}
}(j)), 1000*j);
}
如果您需要具有单独的标识,则环绕非常有用。
var x = function () { cleanup(); };
var y = function () { cleanup(); };
if (x === y) ... // not true
例如,某些函数(如addEventListener
对identity进行操作。
element.addEventListener("myEvent", beep, false);
element.addEventListener("myEvent", beep, false);
第二次调用addEventListener
,它说“我已经beep
了beep
;我不需要添加另一个。” 触发myEvent
事件时,只会发出一声嘟嘟声。 如果您想要发出两声嘟嘟声,则需要确保回调不同。
element.addEventListener("myEvent", function() { beep(); }, false);
element.addEventListener("myEvent", function() { beep(); }, false);
每个匿名函数都不同,所以这次你注册了两个函数(碰巧做同样的事情)。 现在它会发出两声哔哔声。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.