本片文章跟大家分享作者學習Javascript裝飾設計模式後的心得以及要點分享,有興趣的朋友參考下。
裝飾設計模式
每個設都有其獨特的應用場景和解決問題的方式, 裝飾設計模式是動態的為物件添加新的功能, 是一種用來代替繼承的技術,無需透過繼承增加子類別就能擴展物件的新功能。使用物件的關聯關係代替繼承關係,更加靈活,同時避免類型體系的快速膨脹, 這種模式適合新添加的功能不足以用繼承為代價解決問題的情況時使用- 殺雞焉用宰牛刀^_^
裝飾設計模式: 動態地為一個物件添加一些額外的職責,若要擴展一個物件的功能,裝飾者提供了比繼承更有彈性的替代方案。
結構圖:
介面
var Bicycle = new Interface('Bicycle', ['assemble', 'wash', 'repair', 'getPrice']);
物件類別
var AcmeComfortCuiser = function(){ }; AcmeComfortCuiser.prototype = { assemble: function(){ }, wash: function(){ }, repair: function(){ }, getPrice: function(){ } }
裝飾類別
var BicycleDecorator = function(bicycle){ Interface.ensureImplements(bicycle, Bicycle); this.bicycle = bicycle; }; BicycleDecorator.prototype = { assemble: function(){ return this.bicycle.assemble(); }, wash: function(){ return this.bicycle.wash(); }, repair: function(){ return this.bicycle.repair(); }, getPrice: function(){ return this.bicycle.getPrice(); } }
拓展類別
var HeadlightDecorator = function(bicycle){ BicycleDecorator.call(this, bicycle); }; extend(HeadlightDecorator, BicycleDecorator); HeadlightDecorator.prototype.getPrice = function(){ return this.bicycle.getPrice() + 15.00; }
上面是我整理給大家的,希望今後會對大家有幫助。
相關文章:
以上是js裝飾設計模式學習心得(詳細解答)的詳細內容。更多資訊請關注PHP中文網其他相關文章!