UDN-企业互联网技术人气社区
UDN 企业互联网技术社区 前端精选 JavaScript精选 JavaScript设计模式之装饰者模式介绍

JavaScript设计模式之装饰者模式介绍

牛娜 论坛 2016-5-9 13:26
分享到:
摘要: 这篇文章主要介绍了JavaScript设计模式之装饰者模式介绍,通一个类来动态的对另一个类的功能对象进行前或后的修饰,给它辅加一些额外的功能; 这是对一个类对象功能的装饰,装饰的类跟被装饰的类,要求拥有相同的访问 ...
        这篇文章主要介绍了JavaScript设计模式之装饰者模式介绍,通一个类来动态的对另一个类的功能对象进行前或后的修饰,给它辅加一些额外的功能; 这是对一个类对象功能的装饰,装饰的类跟被装饰的类,要求拥有相同的访问接口方法(功能),需要的朋友可以参考下

装饰者模式说明

        说明:通一个类来动态的对另一个类的功能对象进行前或后的修饰,给它辅加一些额外的功能; 这是对一个类对象功能的装饰,装饰的类跟被装饰的类,要求拥有相同的访问接口方法(功能),这在动态面向对象类里,一般以实现同一个接口(interface)来约束实现;装饰类的要有对被装饰类的引用,用于在装饰类的相应方法,调用相应被装饰类的方法,然后对其进行修饰;

场景举例:

        1>. 比如我们生活中的穿衣服, 一件衬衣,一件西装外套,一条裤子,一条领带,一双漂亮的皮鞋; 每多穿一件,都是对前面一件或全身的装饰;

        2>. 比如我们有个类下的功能方法,可能用于写日志,可能用于用户登陆这样的功能,也许写入日志前需要获取当前操作者信息,或是登录成功后,写入一条日志;写入日志之前的额外操作,它的总体来说也还是一个写日志的目的;登孙成功后写日志,它总体上也是一个登录过程的操作信息;

        因此装饰者模式用于实现,两者相似操作的一种场景;就是装饰者对被装饰者功能对象的扩展,本质还是原方法相同的功能范围;

实例源码

1. 被装饰者类


复制代码 代码如下:
  1. function Wear() {
  2.      
  3. }

  4. Wear.prototype.Shirt = function() {
  5.      //穿了件衬衫
  6.   console.log('穿上衬衫');
  7. }
复制代码

2. 装饰者类

复制代码 代码如下:
  1. function Decorator(wear) {
  2.      this.wear = wear;
  3. }

  4. Decorator.prototype.Shirt = function() {
  5.      this.wear.Shirt();
  6.      //穿了件衬衫后,我又加上了领带
  7. }
复制代码

3. 使用方法
复制代码 代码如下:
  1. var wear = new Wear();
  2. var decorator = new Decorator(wear);
  3. decorator.Shirt();
复制代码

        这样就实现了对 Wear 穿衬衫这个功能对象的动态扩展装饰,你也不必知道原被装饰方法是如何执行,只要知道它的功能是什么就可以,然后知道我们要对其辅加的额外功能是什么就可以;

其他说明

        装饰者模式,真正提现了面向对象方法的:对扩展开放,对修改关闭的原则;所有想要的功能方法,都是在没有修改[被装饰类Wear]在扩展[装饰者这个类Decorator]的情况下进行的;

        装饰者模式的一个主要特点,就是装饰者对被装饰者的引用,以实现对被装饰者的无修改装饰;

        模拟下:先穿衬衫,再穿领带,再穿西装的场景: 上面的被装饰者不变了:

2. 装饰者类:

复制代码 代码如下:
  1. function Decorator(wear) {
  2.      this.wear = wear;
  3. }
  4. Decorator.prototype.Shirt = function() {
  5.      this.wear.Shirt(); //这里只穿衬衫;
  6. }
复制代码

3. 创建类似继承 Decorator 子类的 穿领带类与穿西装类

复制代码 代码如下:
  1. function Decorator_Tie(decorator) {
  2.      this.decorator = decorator;
  3. }   
  4. Decorator_Tie.prototype.Shirt = function() {
  5.      this.decorator.Shirt(); //穿上衬衫
  6.      console.log('再戴上领带');
  7. }

  8. function Decorator_Western (decorator) {
  9.      this.decorator =  decorator;
  10. }
  11. Decorator_Western.prototype.Shirt = function() {
  12.      this.decorator.Shirt();
  13.      console.log('再穿上西装');
  14. }
复制代码

使用方法:

复制代码 代码如下:
  1. //先穿上衬衫
  2. var wear = new Wear();
  3. var decorator = new Decorator(wear);
  4. //decorator.Shirt();
  5. //再戴上领带
  6. var tie = new Decorator_Tie(decorator);
  7. //tie.Shirt();
  8. //再穿上西装
  9. var western = new Decorator_Western(tie);
  10. western.Shirt();
复制代码


这就是一个穿衣服装饰的模拟例子;

相关阅读

分享到:
已有2条评论

最新评论

不帅
有空一起交流一下
安分守己
总觉得哪里有点问题啊

一周焦点

关注我们:
关于我们
联系我们
  • 电话:010-86393388
  • 邮件:udn@yonyou.com
  • 地址:北京市海淀区北清路68号
移动客户端下载
关注我们
  • 微信公众号:yonyouudn
  • 扫描右侧二维码关注我们
  • 专注企业互联网的技术社区
版权所有:用友网络科技股份有限公司82041 京ICP备05007539号-11 京公网网备安1101080209224 Powered by Discuz!
返回顶部