相同的JavaScript函数根据上下文其含义会发生变化。bash
// 在程序的顶层做为函数声明
function double() { return x * 2; }
// 做为函数表达式
var f = function double(x) { return x * 2; };
// 匿名函数表达式
var f = function(x) { return x * 2; };
复制代码
命名函数表达式会绑定到与其相同函数名相同的变量上,该变量将做为该函数内的一个局部变量,能够用来写递归函数表达式(命名函数表达式不能经过其内部的函数名在外部被引用)。函数
var f = function find(tree, key) {
if (!tree) {
return null;
}
if (tree.key === key) {
return tree.value;
}
return find(tree, left, key) || find(tree, right, key);
}
复制代码
使用外部做用域的函数名也可到达一样的效果ui
var f = function(tree, key) {
if (!tree) {
return null;
}
if (tree.key === key) {
return tree.value;
}
return f(tree, left, key) || f(tree, right, key);
}
复制代码
只使用一个声明spa
function find(tree, key) {
if (!tree) {
return null;
}
if (tree.key === key) {
return tree.value;
}
return find(tree, left, key) || find(tree, right, key);
}
var f = find;
复制代码
在ES3和有问题的JavaScript环境中命名函数表达式在其做用域内继承了Object.prototype.constructorprototype
var construction = function() { return null; };
var f = function f() {
return construction ();
}
f(); // {}
复制代码
在一些JavaScript引擎中另外一个缺陷是对命名函数表达式的声明进行提高调试
var f = function g() { return 17; };
g(); // 17
// 经过建立一个与函数表达式同名的局部变量并赋值为null来解决
var f = function g() { return 17; };
var g = null;
复制代码