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


Posted in Javascript onDecember 28, 2014

装饰者模式说明

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

场景举例:

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

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

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

实例源码

1. 被装饰者类

function Wear() {

    

}
Wear.prototype.Shirt = function() {

    //穿了件衬衫

console.log('穿上衬衫');

}

2. 装饰者类

function Decorator(wear) {

    this.wear = wear;

}
Decorator.prototype.Shirt = function() {

    this.wear.Shirt();

    //穿了件衬衫后,我又加上了领带

}

3. 使用方法

var wear = new Wear();

var decorator = new Decorator(wear);

decorator.Shirt();

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

其他说明

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

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

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

2. 装饰者类:

function Decorator(wear) {

    this.wear = wear;

}

Decorator.prototype.Shirt = function() {

    this.wear.Shirt(); //这里只穿衬衫;

}

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

function Decorator_Tie(decorator) {

    this.decorator = decorator;

}    

Decorator_Tie.prototype.Shirt = function() {

    this.decorator.Shirt(); //穿上衬衫

    console.log('再戴上领带');

}
function Decorator_Western (decorator) {

    this.decorator =  decorator;

}

Decorator_Western.prototype.Shirt = function() {

    this.decorator.Shirt();

    console.log('再穿上西装');

}

使用方法:

//先穿上衬衫

var wear = new Wear();

var decorator = new Decorator(wear);

//decorator.Shirt();

//再戴上领带

var tie = new Decorator_Tie(decorator);

//tie.Shirt();

//再穿上西装

var western = new Decorator_Western(tie);

western.Shirt();

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

Javascript 相关文章推荐
一个小型js框架myJSFrame附API使用帮助
Jun 28 Javascript
浅谈Javascript嵌套函数及闭包
Nov 09 Javascript
Jquery Uploadify多文件上传带进度条且传递自己的参数
Aug 28 Javascript
JS Loading功能的简单实现
Nov 29 Javascript
Vue.js系列之项目结构说明(2)
Jan 03 Javascript
flexslider.js实现移动端轮播
Feb 05 Javascript
vue中配置mint-ui报css错误问题的解决方法
Oct 11 Javascript
关于vue中watch检测到不到对象属性的变化的解决方法
Feb 08 Javascript
使用vue实现多规格选择实例(SKU)
Aug 23 Javascript
浅析vue-router实现原理及两种模式
Feb 11 Javascript
vue项目实现减少app.js和vender.js的体积操作
Nov 12 Javascript
基于ajax实现上传图片代码示例解析
Dec 03 Javascript
浅谈Javascript Base64 加密解密
Dec 28 #Javascript
JavaScript设计模式之代理模式介绍
Dec 28 #Javascript
JavaScript设计模式之外观模式介绍
Dec 28 #Javascript
JavaScript阻止事件冒泡示例分享
Dec 28 #Javascript
jQuery中removeData()方法用法实例
Dec 27 #Javascript
jQuery中data()方法用法实例
Dec 27 #Javascript
jQuery中index()方法用法实例
Dec 27 #Javascript
You might like
PHP的一个完美GIF等比缩放类,附带去除缩放黑背景
2014/04/01 PHP
采用memcache在web集群中实现session的同步会话
2014/07/05 PHP
PHP实现递归的三种方法
2020/07/04 PHP
java script编程起步(第三课)
2007/01/10 Javascript
Jquery Ajax 学习实例2 向页面发出请求 返回JSon格式数据
2010/03/15 Javascript
用jquery实现下拉菜单效果的代码
2010/07/25 Javascript
javascript中的原型链深入理解
2014/02/24 Javascript
JavaScript获取两个数组交集的方法
2015/06/09 Javascript
浅析AngularJS中的生命周期和延迟处理
2015/06/18 Javascript
Highcharts使用简例及异步动态读取数据
2015/12/30 Javascript
详解Vue中状态管理Vuex
2017/05/11 Javascript
angular中实现li或者某个元素点击变色的两种方法
2017/07/27 Javascript
Vue 滚动行为的具体使用方法
2017/09/13 Javascript
Vue组件库发布到npm详解
2018/02/17 Javascript
vue axios 表单提交上传图片的实例
2018/03/16 Javascript
ionic使用angularjs表单验证(模板验证)
2018/12/12 Javascript
jQuery分组选择器简单用法示例
2019/04/04 jQuery
微信小程序地图绘制线段并且测量(实例代码)
2020/01/02 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
2020/04/27 Javascript
原生js实现移动小球(碰撞检测)
2020/12/17 Javascript
Python 命令行参数sys.argv
2008/09/06 Python
浅谈python中的变量默认是什么类型
2016/09/11 Python
windows系统下Python环境搭建教程
2017/03/28 Python
使用python-pptx包批量修改ppt格式的实现
2020/02/14 Python
python把一个字符串切开的实例方法
2020/09/27 Python
Kidsroom台湾:来自德国的婴儿用品
2017/12/11 全球购物
红色连衣裙精品店:Red Dress Boutique
2018/08/11 全球购物
函授毕业生自我鉴定
2013/11/06 职场文书
欢迎领导标语
2014/06/27 职场文书
副总经理岗位职责范本
2014/09/30 职场文书
人力资源部岗位职责
2015/02/11 职场文书
借条如何写
2015/05/26 职场文书
Nginx服务器如何设置url链接
2021/03/31 Servers
python实现黄金分割法的示例代码
2021/04/28 Python
深入探讨opencv图像矫正算法实战
2021/05/21 Python
tensorflow中的梯度求解及梯度裁剪操作
2021/05/26 Python