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

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

Sep 10, 2024 pm 10:33 PM

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:

1

2

3

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?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

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:

1

2

3

4

5

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:

1

2

3

4

5

6

7

8

// 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!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ersetzen Sie Stringzeichen in JavaScript Ersetzen Sie Stringzeichen in JavaScript Mar 11, 2025 am 12:07 AM

Ersetzen Sie Stringzeichen in JavaScript

JQuery überprüfen, ob das Datum gültig ist JQuery überprüfen, ob das Datum gültig ist Mar 01, 2025 am 08:51 AM

JQuery überprüfen, ob das Datum gültig ist

JQuery Get Element Polsterung/Rand JQuery Get Element Polsterung/Rand Mar 01, 2025 am 08:53 AM

JQuery Get Element Polsterung/Rand

10 JQuery Accords Registerkarten 10 JQuery Accords Registerkarten Mar 01, 2025 am 01:34 AM

10 JQuery Accords Registerkarten

10 lohnt 10 lohnt Mar 01, 2025 am 01:29 AM

10 lohnt

HTTP-Debugging mit Knoten und HTTP-Konsole HTTP-Debugging mit Knoten und HTTP-Konsole Mar 01, 2025 am 01:37 AM

HTTP-Debugging mit Knoten und HTTP-Konsole

JQuery fügen Sie Scrollbar zu Div hinzu JQuery fügen Sie Scrollbar zu Div hinzu Mar 01, 2025 am 01:30 AM

JQuery fügen Sie Scrollbar zu Div hinzu

Benutzerdefinierte Google -Search -API -Setup -Tutorial Benutzerdefinierte Google -Search -API -Setup -Tutorial Mar 04, 2025 am 01:06 AM

Benutzerdefinierte Google -Search -API -Setup -Tutorial

See all articles