ES6设计模式之策略模式

策略模式的本质,也是设计模式的本质,是将易变化的部分分离出去,不管是对象和对象的行为分离,还是对象和对象表现分离等,都遵循。这是最基本的设计原则。然后把他们组合到一起,生成你需要的,不要管那么多设计原则,最终的目的是好维护,易读懂。

class Duck{ constructor(id){ this.id = id; } getid(){ console.log(this.id); }

display(){ console.log(“a nomal duck”); } }

class FlyBefavior{ constructor(wings){ this.wings = wings; } fly(){ console.log(fly with ${ this.wings}!); } }

class QuackBefavior{ constructor(sound){ this.sound = sound; } quack(){ console.log(duck make sound,${this.sound}); } }

class swimBefavior{ constructor(){

} swim(){ console.log(“duck swim in water.”); } }

class MallardDuck extends Duck{ constructor(id){ super(id); this.mallfly = new FlyBefavior(“green wings”); this.mallquack = new QuackBefavior(“gua gua gua”); }

fly(){ this.mallfly.fly(); }

quack(){ this.mallquack.quack() }

display(){ console.log(‘yee,a green head duck.’); } }

var m_duck = new MallardDuck(‘002’);

m_duck.display(); m_duck.getid(); m_duck.fly(); m_duck.quack();

转载于:https://www.cnblogs.com/node-jili/p/10161465.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值