JS設計模式(一)--- 工廠模式
故事的開頭是這樣子的…
在很久很久以前,有一個學生叫小明
有一天,老師對小明,小明啊,你去給班上買一個籃球,一個足球,一套積木和一套樂高
class Good {
constructor(name, price) {
this.name = name;
this.price = price;
}
showInfo() {
console.log(`商品名:${this.name} 價格:¥${this.price}`);
}
}
class Shop {
constructor(customer) {
this.customer = customer;
}
sell(good) {
this.customer.buy(good);
this.customer.total += good.price;
}
}
class ToyShop extends Shop{
constructor(customer) {
super(customer);
}
sell(name) {
switch(name) {
case '樂高': super.sell(new Good('樂高', 3600));
case '積木': super.sell(new Good('積木', 288));
}
}
}
class SportShop extends Shop{
constructor(customer) {
super(customer);
}
sell(name) {
switch(name) {
case '足球': super.sell(new Good('足球', 80));
case '籃球': super.sell(new Good('籃球', 65));
}
}
}
class Student {
constructor(name) {
this.name = name;
this.goodList = [];
this.total = 0;
}
buy(good) {
this.goodList.push(good);
}
getTotal() {
console.log(`${this.name}一共花費了¥${this.total}`);
}
}
於是,小明拿著錢,走在大街上…
let xiaoming = new Student('小明');
小明進了球具店,買了足球和籃球
let sportShop = new SportShop(xiaoming);
sportShop.sell('足球');
sportShop.sell('籃球');
小明進了文具店,買了樂高和積木
let toyShop = new ToyShop(xiaoming);
toyShop.sell('樂高');
toyShop.sell('積木');
小明結束了採購
xiaoming.getTotal();
小明並不關心每次購買的過程是怎樣的:商家庫存少了一個商品,商家盈利了多少錢,小明賬單上多了多少錢
小明只關注一件事情:商家賣出了一件商品給我
相關文章
- JS設計模式一:工廠模式JS設計模式
- 設計模式之工廠模式(一)設計模式
- 一.設計模式之工廠設計模式設計模式
- 設計模式-工廠模式二(工廠方法模式)設計模式
- 【設計模式】工廠模式設計模式
- 設計模式 —— 工廠模式設計模式
- 設計模式-工廠模式設計模式
- 設計模式(工廠模式)設計模式
- 設計模式——工廠模式設計模式
- 設計模式----工廠模式設計模式
- 設計模式-簡單工廠、工廠方法模式、抽象工廠模式設計模式抽象
- 設計模式----工廠設計模式設計模式
- 設計模式-工廠設計模式設計模式
- 設計模式之工廠方法模式|抽象工廠模式設計模式抽象
- 設計模式(一)—— 簡單工廠模式設計模式
- java設計模式之一 工廠模式Java設計模式
- C# 設計模式(1)——簡單工廠模式、工廠模式、抽象工廠模式C#設計模式抽象
- 設計模式之工廠模式!深入解析簡單工廠模式,工廠方法模式和抽象工廠模式設計模式抽象
- 設計模式學習(二)工廠模式——抽象工廠模式設計模式抽象
- 設計模式——抽象工廠模式設計模式抽象
- 設計模式 —— 抽象工廠模式設計模式抽象
- PHP設計模式-- 工廠模式PHP設計模式
- 設計模式-抽象工廠模式設計模式抽象
- Java設計模式(工廠模式)Java設計模式
- Java設計模式--工廠模式Java設計模式
- Java 設計模式(工廠模式)Java設計模式
- java設計模式-工廠模式Java設計模式
- 設計模式 - 工廠方法模式設計模式
- 設計模式之工廠模式設計模式
- java設計模式 – 工廠模式Java設計模式
- 設計模式 #2 (工廠模式)設計模式
- 設計模式之【工廠模式】設計模式
- 設計模式-工廠方法模式設計模式
- 設計模式~~~工廠方法模式設計模式
- PHP設計模式_工廠模式PHP設計模式
- 設計模式——工廠方法模式設計模式
- 設計模式(四)工廠模式設計模式
- Java設計模式:工廠模式Java設計模式