首頁  >  文章  >  web前端  >  JavaScript 設計模式 - 行為 - 策略

JavaScript 設計模式 - 行為 - 策略

WBOY
WBOY原創
2024-08-16 18:36:05874瀏覽

JavaScript Design Patterns - Behavioral - Strategy

策略模式定義了一系列演算法,封裝了每個演算法,並使它們可以互換。

在此範例中,我們有一組可應用於購物車的折扣。我們可以傳遞將應用於建構函數的函數,並以這種方式更改折扣金額。

class ShoppingCart {
  constructor(discount) {
    this.discount = discount;
    this.amount = 0;
  }

  checkout() {
    return this.discount(this.amount);
  }

  setAmount(amount) {
    this.amount = amount;
  }
}

function guest(amount) {
  return amount;
}

function regular(amount) {
  return amount * 0.9;
}

function premium(amount) {
  return amount * 0.8;
}

export { ShoppingCart, guest, regular, premium };

完整的例子在這裡? https://stackblitz.com/edit/vitejs-vite-tygwh3?file=strategy.js

結論

當您有許多相似的類,僅在執行某些行為的方式上有所不同時,請使用此模式。


希望您覺得它有幫助。感謝您的閱讀。 ?

讓我們聯絡吧!你可以在以下位置找到我:

  • 中: https://medium.com/@nhannguyendevjs/
  • 開發:https://dev.to/nhannguyendevjs/
  • 雜湊節點:https://nhannguyen.hashnode.dev/
  • Linkedin: https://www.linkedin.com/in/nhannguyendevjs/
  • X(以前的 Twitter):https://twitter.com/nhannguyendevjs/
  • 請我喝杯咖啡: https://www.buymeacoffee.com/nhannguyendevjs

以上是JavaScript 設計模式 - 行為 - 策略的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn