„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 – Zustand

JavaScript-Entwurfsmuster – Verhalten – Zustand

Veröffentlicht am 20.08.2024
Durchsuche:469

JavaScript Design Patterns - Behavioral - State

Das Muster state ermöglicht es einem Objekt, sein Verhalten zu ändern, wenn sich sein interner Zustand ändert.

In diesem Beispiel erstellen wir ein einfaches Statusmuster mit einer Order-Klasse, die den Status mit der Methode next() aktualisiert.

const ORDER_STATUS = {
  waitingForPayment: 'Waiting for payment',
  shipping: 'Shipping',
  delivered: 'Delivered',
};

class OrderStatus {
  constructor(name, nextStatus) {
    this.name = name;
    this.nextStatus = nextStatus;
  }

  next() {
    return new this.nextStatus();
  }
}

class WaitingForPayment extends OrderStatus {
  constructor() {
    super(ORDER_STATUS.waitingForPayment, Shipping);
  }
}

class Shipping extends OrderStatus {
  constructor() {
    super(ORDER_STATUS.shipping, Delivered);
  }
}

class Delivered extends OrderStatus {
  constructor() {
    super(ORDER_STATUS.delivered, Delivered);
  }
}

class Order {
  constructor() {
    this.state = new WaitingForPayment();
  }

  next() {
    this.state = this.state.next();
  }
}

export { Order };

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

Abschluss

Verwenden Sie dieses Muster, wenn das Verhalten des Objekts von seinem Zustand abhängt und sich sein Verhalten zur Laufzeit abhängig von diesem Zustand ä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-state-3e9b?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