JavaScript ist zwar flexibel, bringt aber auch einige Verwirrung mit sich. Sie können beispielsweise mehrere Möglichkeiten verwenden, um dasselbe zu tun, z. B. Funktionen, Objekte usw. erstellen. Was ist also der Unterschied zwischen den beiden im Titel genannten?
Neue Funktion ist eine andere Möglichkeit, eine Funktion zu erstellen, ihre Syntax:
const func = neue Funktion ([arg1, arg2, ...argN], functionBody);
Ein einfaches Beispiel:
const sum = new Function('a', 'b', 'return a + b'); sum(1 + 2); // 3
Nun, das gibt große Flexibilität. Es ist nicht üblich, aber es gibt einige Fälle, in denen es verwendet werden kann. Wir können es beispielsweise verwenden, wenn wir eine Vorlage dynamisch in eine Funktion kompilieren müssen, was meines Wissens nach auch bei Vue.js der Fall ist. Darüber hinaus kann es auch verwendet werden, wenn wir Codezeichenfolgen vom Server empfangen müssen, um Funktionen dynamisch zu erstellen.
Lassen Sie uns kurz über seine Funktionen sprechen. Sehen Sie, was der folgende Code ausgibt?
globalThis.a = 10; function createFunction1() { const a = 20; return new Function('return a;'); } function createFunction2() { const a = 20; function f() { return a; } return f; } const f1 = createFunction1(); console.log(f1()); // ? const f2 = createFunction2(); console.log(f2()); // ?
Die Antwort ist 10 und 20. Dies liegt daran, dass neue Funktionen immer Funktionen im globalen Bereich erstellen. Bei der Ausführung kann nur auf globale Variablen und ihre eigenen lokalen Variablen zugegriffen werden.
Während new function() dazu gedacht ist, ein neues Objekt zu erstellen und eine anonyme Funktion als Konstruktor anzuwenden. Wie das folgende Beispiel:
const a = new (function () { this.name = 1; })(); console.log(a); // { name: 1 }
Das ist es. Tatsächlich ist jede JavaScript-Funktion ein Funktionsobjekt, mit anderen Worten, (function () {}).constructor === Function gibt true zurück.
Ein damit verbundener Wissenspunkt ist, wie man mit new Function() eine asynchrone Funktion erstellt. MDN gab uns die Antwort:
// Since `AsyncFunction` is not a global object, we need to get it manually: const AsyncFunction = (async function () {}).constructor; const fetchURL = new AsyncFunction('url', 'return await fetch(url);'); fetchURL('/') .then((res) => res.text()) .then(console.log);
Wenn Sie dies hilfreich fanden, denken Sie bitte darüber nach Abonnieren Sie meinen Newsletter für weitere nützliche Artikel und Tools zur Webentwicklung. Danke fürs Lesen!
Das obige ist der detaillierte Inhalt vonUnterschied zwischen new Function() und new function() in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!