„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > JavaScript-Entwurfsmuster – Verhalten – Beobachter

JavaScript-Entwurfsmuster – Verhalten – Beobachter

Veröffentlicht am 18.08.2024
Durchsuche:586

JavaScript Design Patterns - Behavioral - Observer

Das Muster observer ermöglicht die Definition einer Eins-zu-viele-Abhängigkeit zwischen Objekten, sodass alle abhängigen Objekte automatisch benachrichtigt und aktualisiert werden, wenn ein Objekt seinen Status ändert.

In diesem Beispiel erstellen wir ein einfaches Klassenprodukt, das andere Klassen beim Registrieren von Änderungen in der Methode register() beobachten können. Wenn etwas aktualisiert wird, kommuniziert die Methode notifyAll() mit allen Beobachtern über diese Änderungen.

class ObservedProduct {
  constructor() {
    this.price = 0;
    this.actions = [];
  }

  setBasePrice(val) {
    this.price = val;
    this.notifyAll();
  }

  register(observer) {
    this.actions.push(observer);
  }

  unregister(observer) {
    this.actions.remove.filter(function (el) {
      return el !== observer;
    });
  }

  notifyAll() {
    return this.actions.forEach(
      function (el) {
        el.update(this);
      }.bind(this)
    );
  }
}

class Fees {
  update(product) {
    product.price = product.price * 1.2;
  }
}

class Profit {
  update(product) {
    product.price = product.price * 2;
  }
}

export { ObservedProduct, Fees, Profit };

Ein vollständiges Beispiel finden Sie hier? https://stackblitz.com/edit/vitejs-vite-kyucyd?file=main.js

Abschluss

Verwenden Sie dieses Muster, wenn Änderungen am Zustand eines Objekts möglicherweise die Änderung anderer Objekte erfordern und der tatsächliche Satz von Objekten vorher unbekannt ist oder sich dynamisch ändert.


Ich hoffe, Sie fanden es hilfreich. Danke fürs Lesen. ?

Lassen Sie uns in Kontakt treten! Sie finden mich unter:

  • Medium: https://medium.com/@nhannguyendevjs/
  • Entwickler: https://dev.to/nhannguyendevjs/
  • Hashnode: https://nhannguyen.hashnode.dev/
  • Linkedin: https://www.linkedin.com/in/nhannguyendevjs/
  • X (ehemals Twitter): https://twitter.com/nhannguyendevjs/
  • Kauf mir einen Kaffee: https://www.buymeacoffee.com/nhannguyendevjs
Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/nhannguyendevjs/javascript-design-patterns-behavioral-observer-g70?1 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3