Heim > Web-Frontend > js-Tutorial > Unterschied zwischen new Function() und new function() in JavaScript

Unterschied zwischen new Function() und new function() in JavaScript

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2024-09-10 22:33:32
Original
1222 Leute haben es durchsucht

Difference Between new Function() and new function() in JavaScript

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
Nach dem Login kopieren

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()); // ?
Nach dem Login kopieren

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 }
Nach dem Login kopieren

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);
Nach dem Login kopieren

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!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage