首頁  >  文章  >  web前端  >  js裝飾設計模式詳解

js裝飾設計模式詳解

小云云
小云云原創
2018-02-22 09:11:021273瀏覽

裝飾設計模式:

每種設都有其獨特的應用場景和解決問題的方式, 裝飾設計模式是動態的為物件添加新的功能, 是一種用來代替繼承的技術,無需透過繼承增加子類別就能擴展物件的新功能。使用物件的關聯關係代替繼承關係,更加靈活,同時避免類型體系的快速膨脹, 這種模式適合新添加的功能不足以用繼承為代價解決問題的情況時使用- 殺雞焉用宰牛刀^_^
裝飾設計模式: 動態地為一個物件添加一些額外的職責,若要擴展一個物件的功能,裝飾者提供了比繼承更有彈性的替代方案。

結構圖:

介面


##

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;
  }

相關推薦:


Node.js中通用基礎設計模式實例分析

php設計模式之服務定位器模式實例詳解

#詳解PHP設計模式備忘錄模式

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

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