"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > Patrones de diseño de JavaScript - Comportamiento - Estado

Patrones de diseño de JavaScript - Comportamiento - Estado

Publicado el 2024-08-20
Navegar:200

JavaScript Design Patterns - Behavioral - State

El patrón estado permite que un objeto altere su comportamiento cuando cambia su estado interno.

En este ejemplo, creamos un patrón de estado simple con una clase de Orden que actualizará el estado con el método next().

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 };

¿Aquí hay un ejemplo completo? https://stackblitz.com/edit/vitejs-vite-6zcfql?file=state.js

Conclusión

Utilice este patrón cuando el comportamiento del objeto dependa de su estado y su comportamiento cambie en tiempo de ejecución dependiendo de ese estado.


Espero que te haya resultado útil. Gracias por leer. ?

¡Conectémonos! Puedes encontrarme en:

  • Medio: https://medium.com/@nhannguyendevjs/
  • Desarrollador: https://dev.to/nhannguyendevjs/
  • Hashnode: https://nhannguyen.hashnode.dev/
  • Linkedin: https://www.linkedin.com/in/nhannguyendevjs/
  • X (anteriormente Twitter): https://twitter.com/nhannguyendevjs/
  • Cómprame un café: https://www.buymeacoffee.com/nhannguyendevjs
Declaración de liberación Este artículo se reproduce en: https://dev.to/nhannguyendevjs/javascript-design-patterns-behavioral-state-3e9b?1 Si hay alguna infracción, comuníquese con [email protected] para eliminarla.
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3