javascript - 命名匿名函数与匿名函数

标签 javascript function anonymous-function

所以我对何时使用匿名函数感到困惑,例如:

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/

相关文章:

javascript - 在Javascript中过滤二维数组

javascript - FormData 对象仅获取文件输入,而不获取其他输入,例如文本

C++ : Function overloading vs Variadic function vs Variadic template vs default parameter

c - 学术论文中遇到的奇怪C构造

javascript - 数组中的每个元素同时递增,而实际上只应该递增一个元素

javascript - 从 JSON 对象获取数据时出现问题

javascript - 如何使每个部分适合 li 框?

function - 匿名函数 vs 非匿名函数 Lua

javascript - 如何在 JavaScript 中使我的函数匿名?

javascript - 如何将对象的链接传输给匿名函数?