Inhaltsverzeichnis
Wenn der Wert davon festgelegt ist
Der Fall von Rückruffunktionen
Heim Web-Frontend js-Tutorial Was bestimmt den Wert von „this', wenn eine Callback-Funktion aufgerufen wird?

Was bestimmt den Wert von „this', wenn eine Callback-Funktion aufgerufen wird?

Nov 04, 2024 am 03:56 AM

What Determines the Value of `this` When a Callback Function Is Called?

Wenn der Wert davon festgelegt ist

In JavaScript wird der Wert davon dadurch bestimmt, wie eine Funktion aufgerufen wird. Es gibt sechs primäre Möglichkeiten, dies festzulegen:

  1. Normaler Funktionsaufruf: Dies wird auf das globale Objekt (z. B. ein Fenster in einem Browser) oder im strikten Modus auf undefiniert gesetzt.
  2. Methodenaufruf: Dies wird auf das Objekt gesetzt, für das die Methode aufgerufen wird.
  3. .apply() oder .call(): Dies wird auf das als erstes Argument übergebene Objekt gesetzt.
  4. new-Operator: Wenn eine Funktion mit new aufgerufen wird, wird ein neues Objekt erstellt und dieses auf dieses Objekt gesetzt.
  5. .bind(): Erstellt eine neue Stub-Funktion, bei der diese an das als erstes Argument übergebene Objekt gebunden ist.
  6. ES6 Fat Arrow-Funktion: this ist an den lexikalischen Wert des umschließenden Bereichs gebunden.

Der Fall von Rückruffunktionen

In Ihrem Beispiel:

<code class="javascript">randomFunction(this.sumData.bind(this));</code>
Nach dem Login kopieren
  • this.sumData .bind(this) verwendet .bind(), um dies an das obj-Objekt zu binden.
  • Folglich wird, wenn randomFunction die Callback-Funktion aufruft, diese aufgrund von .bind() auf obj gesetzt.
  • Wenn Sie this.sumData.bind(this) mit callback(data) austauschen würden, würde diese interne randomFunction auf das globale Objekt gesetzt (oder im strikten Modus undefiniert) werden.

Das ist weil Callback als Referenz auf this.sumData.bind(this) übergeben wird, aber wenn randomFunction Callback aufruft, legt es dies gemäß den Regeln eines normalen Funktionsaufrufs fest.

Das obige ist der detaillierte Inhalt vonWas bestimmt den Wert von „this', wenn eine Callback-Funktion aufgerufen wird?. 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

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

Beispielfarben JSON -Datei Beispielfarben JSON -Datei Mar 03, 2025 am 12:35 AM

Beispielfarben JSON -Datei

8 atemberaubende JQuery -Seiten -Layout -Plugins 8 atemberaubende JQuery -Seiten -Layout -Plugins Mar 06, 2025 am 12:48 AM

8 atemberaubende JQuery -Seiten -Layout -Plugins

10 JQuery Syntax Highlighters 10 JQuery Syntax Highlighters Mar 02, 2025 am 12:32 AM

10 JQuery Syntax Highlighters

Erstellen Sie Ihre eigenen AJAX -Webanwendungen Erstellen Sie Ihre eigenen AJAX -Webanwendungen Mar 09, 2025 am 12:11 AM

Erstellen Sie Ihre eigenen AJAX -Webanwendungen

Was ist ' this ' in JavaScript? Was ist ' this ' in JavaScript? Mar 04, 2025 am 01:15 AM

Was ist ' this ' in JavaScript?

10 JavaScript & JQuery MVC -Tutorials 10 JavaScript & JQuery MVC -Tutorials Mar 02, 2025 am 01:16 AM

10 JavaScript & JQuery MVC -Tutorials

See all articles