所以我对何时使用匿名函数感到困惑,例如:
let foo = function () {
//code
}
相对于命名的匿名函数,例如:
let foo = function foo () {
//code
}
除了浏览器支持,即IE,两者之间还有什么区别吗?我什么时候应该使用一个而不是另一个?
最佳答案
在这种情况下,函数声明名称与其分配给的变量相同,并没有太大区别。
如果您对定义和赋值使用了不同的名称,则右侧的名称在命名函数时优先:
foo = function bar() {}
foo.name // "bar"
在这两种情况下,您都将函数分配给一个变量(函数表达式),但在第一种情况下,您分配了一个未命名/匿名函数,而在第二种情况下,您分配了一个命名函数。在这样一个简单的表达式中将匿名函数分配给变量时,JS 引擎能够正确命名该函数。
考虑以下情况,其中此分配对引擎而言不是显而易见的:
function p(fun) { return fun; }
foo = p(function() {})
foo.name // empty string
长话短说;使用命名函数,您通常可以获得更好的堆栈跟踪。
关于javascript - 命名匿名函数与匿名函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48515483/