在 JavaScript 中向函数体动态添加嵌套函数
Add a nested function to a function body dynamically in JavaScript
在JavaScript中可以在函数中包含函数。
function cow() {
function moo() {
console.log("moo");
}
moo();
}
cow();
是否可以动态添加嵌套函数?是这样的吗?
function cow() {
moo();
}
cow.moo = function () {
console.log("moo1");
};
cow();
好吧,如果你问“是否可能”,那么遗憾的是答案是肯定的:
function cow(fn) {
let see = "oh no";
eval(fn.toString())();
}
cow(function moo() {
console.log(see);
});
但除了这个 hack 之外,它实际上是不可能的,因为 JavaScript 有 词法范围 ,这意味着只有源代码中的位置决定了哪个函数可以访问的变量。您不能更改源代码中的位置(除非您将字符串动态评估为代码,您不应该这样做)。
如果只是动态调用一些函数,而不从外部函数访问变量,那么你可以只传递一个函数作为参数(这实际上在JavaScript):
function cow(moo) {
moo();
}
cow(function mooo() {
console.log("mooo");
});
当然你也可以将参数传递给 moo()
调用并在 mooo
函数(或任何其他函数)中接收它们。
在JavaScript中可以在函数中包含函数。
function cow() {
function moo() {
console.log("moo");
}
moo();
}
cow();
是否可以动态添加嵌套函数?是这样的吗?
function cow() {
moo();
}
cow.moo = function () {
console.log("moo1");
};
cow();
好吧,如果你问“是否可能”,那么遗憾的是答案是肯定的:
function cow(fn) {
let see = "oh no";
eval(fn.toString())();
}
cow(function moo() {
console.log(see);
});
但除了这个 hack 之外,它实际上是不可能的,因为 JavaScript 有 词法范围 ,这意味着只有源代码中的位置决定了哪个函数可以访问的变量。您不能更改源代码中的位置(除非您将字符串动态评估为代码,您不应该这样做)。
如果只是动态调用一些函数,而不从外部函数访问变量,那么你可以只传递一个函数作为参数(这实际上在JavaScript):
function cow(moo) {
moo();
}
cow(function mooo() {
console.log("mooo");
});
当然你也可以将参数传递给 moo()
调用并在 mooo
函数(或任何其他函数)中接收它们。