«Если рабочий хочет хорошо выполнять свою работу, он должен сначала заточить свои инструменты» — Конфуций, «Аналитики Конфуция. Лу Лингун»
титульная страница > программирование > Шаблоны проектирования JavaScript — поведенческие — состояние

Шаблоны проектирования JavaScript — поведенческие — состояние

Опубликовано 20 августа 2024 г.
Просматривать:512

JavaScript Design Patterns - Behavioral - State

Шаблон state позволяет объекту изменять свое поведение при изменении его внутреннего состояния.

В этом примере мы создаем простой шаблон состояния с классом Order, который будет обновлять статус с помощью метода 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 };

Полный пример здесь? https://stackblitz.com/edit/vitejs-vite-6zcfql?file=state.js

Заключение

Используйте этот шаблон, когда поведение объекта зависит от его состояния, а его поведение меняется во время выполнения в зависимости от этого состояния.


Надеюсь, это было вам полезно. Спасибо за чтение. ?

Давайте соединяться! Вы можете найти меня:

  • Средний: https://medium.com/@nhannguyendevjs/
  • Разработчик: https://dev.to/nhannguyendevjs/
  • Hashnode: https://nhannguyen.hashnode.dev/
  • Linkedin: https://www.linkedin.com/in/nhannguyendevjs/
  • X (ранее Twitter): https://twitter.com/nhannguyendevjs/
  • Купи мне кофе: https://www.buymeacoffee.com/nhannguyendevjs
Заявление о выпуске Эта статья воспроизводится по адресу: https://dev.to/nhannguyendevjs/javascript-design-patterns-behavioral-state-3e9b?1 Если есть какие-либо нарушения, пожалуйста, свяжитесь с учебным пособием[email protected], чтобы удалить его.
Последний учебник Более>

Изучайте китайский

Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.

Copyright© 2022 湘ICP备2022001581号-3