看看用TypeScript怎樣實(shí)現(xiàn)常見(jiàn)的設(shè)計(jì)模式,順便復(fù)習(xí)一下。
學(xué)模式最重要的不是記UML,而是知道什么模式可以解決什么樣的問(wèn)題,在做項(xiàng)目時(shí)碰到問(wèn)題可以想到用哪個(gè)模式可以解決,UML忘了可以查,思想記住就好。
這里盡量用原創(chuàng)的,實(shí)際中能碰到的例子來(lái)說(shuō)明模式的特點(diǎn)和用處。
裝飾模式 Decorator
特點(diǎn):在不改變接口的情況下,裝飾器通過(guò)組合方式引用對(duì)象,并由此在保持對(duì)象原有功能的基礎(chǔ)上給對(duì)象加上新功能。
用處:當(dāng)需要不影響現(xiàn)有類并增加新的功能時(shí),可以考慮裝飾模式,它可以動(dòng)態(tài)透明的給對(duì)象增加功能。
注意:與繼承的優(yōu)劣。
下面用TypeScript簡(jiǎn)單實(shí)現(xiàn)一下裝飾模式:
現(xiàn)在有一輛小轎車,加速到100km/h需要10秒:
interface Movable{ accelerate(); }class Car implements Movable{ accelerate(){ console.log('加速到100km/h需要10秒'); } }
現(xiàn)在想改裝下,提高加速度,加個(gè)渦輪增壓器。
class TurboCharger{ use(){ console.log('使用渦輪增壓'); } }class RefittedCar implements Movable{ construct(private car: Car){ } turboCharger = new TurboCharger(); accelerate(){ this.car.accelerate(); this.turboCharger.use(); console.log('加速到100km/h需要5秒'); } }let refitterCar: Movable = new RefittedCar(new Car()); refitterCar.accelerate();//輸出:加速到100km/h需要10秒 使用渦輪增壓 加速到100km/h需要5秒
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動(dòng)安全 [無(wú)線安全]玩轉(zhuǎn)無(wú)線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識(shí)別反義詞同義詞 2017-07-26
- 從棧不平衡問(wèn)題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動(dòng)安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來(lái)看看(二) 2017-07-26