首頁 >web前端 >js教程 >詳細解讀js中裝飾設計模式

詳細解讀js中裝飾設計模式

亚连
亚连原創
2018-06-05 17:29:511805瀏覽

本片文章跟大家分享作者學習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;
  }

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

Vue.js實作圖片的隨意拖曳方法

JS字串移除連續或全部重複字元的實例

vue.js或js實作中文A-Z排序的方法

以上是詳細解讀js中裝飾設計模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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