Verständnis von this, Bind, Call und Apply in JavaScript

Wie funktioniert „this“ in JavaScript und wie kann es in verschiedenen Kontexten genutzt werden? Wir zeigen es Ihnen und erklären außerdem, wie Sie „bind“, „call“ und „apply“ verwenden können, um die Kontrolle über „this“ in Ihren JavaScript-Funktionen zu behalten.

Das this-Schlüsselwort

In JavaScript bezieht sich „this“ auf ein Objekt, und je nachdem, wie und wo es aufgerufen wird, kann es auf unterschiedliche Objekte verweisen. Schauen wir uns verschiedene Kontexte an:

Globaler Kontext

Im globalen Kontext verweist „this“ auf das globale Objekt, das in einem Browser „window“ und in Node.js „global“ ist.

Beispiel:


Ausgabe (im Browser):

Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, parent: Window, …}

Methode in einem Objekt

Wenn eine Funktion eine Methode eines Objekts ist, verweist „this“ auf dieses Objekt.

Beispiel:

    const auto = {
  marke: 'BMW',
  modell: 'X5',
  vorstellen: function() {
    console.log(`Ich fahre einen ${this.marke} ${this.modell}.`);
  }
}

auto.vorstellen();


Ausgabe:

Ich fahre einen BMW X5.

Konstruktorfunktion

Wenn Sie eine Funktion als Konstruktor verwenden, um Objekte zu erstellen, verweist „this“ auf das neu erstellte Objekt.

Beispiel:

 
   function Person(name, alter) {
  this.name = name;
  this.alter = alter;
}

const alice = new Person('Alice', 30);

console.log(alice.name); // Ausgabe: Alice  

DOM-Ereignishandler

In einem DOM-Ereignishandler verweist „this“ auf das Element, auf das der Ereignishandler angewendet wurde.

Beispiel:

 const button = document.getElementById('myButton');
button.addEventListener('click', function() {
  console.log(this.textContent);
});   
    


Wenn der Button geklickt wird, gibt der Ereignishandler den Text des Buttons aus.

Die Methoden „bind“, „call“ und „apply“

Die Methode „bind“

Die Methode „bind“ ermöglicht es, eine Funktion an ein bestimmtes Objekt zu binden. Die ursprüngliche Funktion bleibt unverändert, aber bei Aufruf der gebundenen Funktion wird „this“ auf das angegebene Objekt gesetzt.

Beispiel:

 const hund = {
  name: 'Rex',
  bellen: function() {
    console.log(`${this.name} bellt.`);
  }
}

const katze = {
  name: 'Whiskers'
}

const bellenDerKatze = hund.bellen.bind(katze);

bellenDerKatze(); // Ausgabe: Whiskers bellt.   
    

Die Methoden „call“ und „apply“

Die Methoden „call“ und „apply“ ermöglichen es, eine Funktion aufzurufen und den Wert von „this“ sowie Argumente explizit festzulegen. Der Unterschied zwischen den beiden Methoden besteht darin, wie Sie Argumente übergeben:

  • „call“ erwartet, dass die Argumente einzeln übergeben werden.
  • „apply“ erwartet, dass die Argumente in einem Array übergeben werden.

Beispiel mit „call“:

function grüßen(geschlecht) {
  if (geschlecht === 'männlich') {
    console.log(`Hallo, Herr ${this.name}!`);
  } else if (geschlecht === 'weiblich') {
    console.log(`Hallo, Frau ${this.name}!`);
  } else {
    console.log(`Hallo, ${this.name}!`);
  }
}

const person = {
  name: 'Max'
}

grüßen.call(person, 'männlich'); // Ausgabe: Hallo, Herr Max!    
    


Beispiel mit „apply“:

   const argumente = ['weiblich'];

grüßen.apply(person, argumente); // Ausgabe: Hallo, Frau Max! 
    

Fazit

In JavaScript ist das Verständnis von „this“ und die Verwendung der Methoden „bind“, „call“ und „apply“ entscheidend, um den Kontext und die Ausführung von Funktionen zu steuern. Mit diesem Wissen können Sie sicherstellen, dass Ihre Funktionen auf die richtigen Objekte zugreifen und korrekt ausgeführt werden.

Kostenlosen Account erstellen

Registrieren Sie sich jetzt und erhalten Sie Zugang zu unseren Cloud Produkten.

Das könnte Sie auch interessieren: