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 相关文章推荐
JavaScript Accessor实现说明
Dec 06 Javascript
深入理解JavaScript系列(4) 立即调用的函数表达式
Jan 15 Javascript
AngularJS中的过滤器使用详解
Jun 16 Javascript
分离与继承的思想实现图片上传后的预览功能:ImageUploadView
Apr 07 Javascript
BootStrap3中模态对话框的使用
Jan 06 Javascript
vue-router实现webApp切换页面动画效果代码
May 25 Javascript
bootstrap实现二级下拉菜单效果
Nov 23 Javascript
10分钟彻底搞懂Http的强制缓存和协商缓存(小结)
Aug 30 Javascript
微信小程序 checkbox使用实例解析
Sep 09 Javascript
基于JavaScript实现单例模式
Oct 30 Javascript
vant-ui AddressEdit地址编辑和van-area的用法说明
Nov 03 Javascript
javascript实现点击小图显示大图
Nov 29 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+DBM的同学录程序(4)
2006/10/09 PHP
谷歌音乐搜索栏的提示功能php修正代码
2011/05/09 PHP
php循环创建目录示例分享(php创建多级目录)
2014/03/04 PHP
PHP中auto_prepend_file与auto_append_file用法实例分析
2014/09/22 PHP
PHP文件打开关闭及读写操作示例解析
2020/08/06 PHP
PHP如何通过date() 函数格式化显示时间
2020/11/13 PHP
读jQuery之六 缓存数据功能介绍
2011/06/21 Javascript
jQuery EasyUI API 中文文档 - ProgressBar 进度条
2011/09/29 Javascript
js相册效果代码(点击创建即可)
2013/04/16 Javascript
JavaScript按位运算符的应用简析
2014/02/04 Javascript
JS去除iframe滚动条的方法
2015/04/01 Javascript
全面了解addEventListener和on的区别
2016/07/14 Javascript
Jquery删除css属性的简单方法
2016/12/04 Javascript
详解浏览器渲染页面过程
2017/02/09 Javascript
JS实现禁止用户使用Ctrl+鼠标滚轮缩放网页的方法
2017/04/28 Javascript
JS点击图片弹出文件选择框并覆盖原图功能的实现代码
2017/08/25 Javascript
JS使用iView的Dropdown实现一个右键菜单
2019/05/06 Javascript
[57:55]完美世界DOTA2联赛PWL S3 Magma vs Phoenix 第二场 12.12
2020/12/16 DOTA
[01:01:52]DOTA2-DPC中国联赛正赛 iG vs LBZS BO3 第一场 3月4日
2021/03/11 DOTA
Python和GO语言实现的消息摘要算法示例
2015/03/10 Python
使用Python实现一个简单的项目监控
2015/03/31 Python
Python xlrd读取excel日期类型的2种方法
2015/04/28 Python
python比较2个xml内容的方法
2015/05/11 Python
python 第三方库的安装及pip的使用详解
2017/05/11 Python
使用python编写简单的小程序编译成exe跑在win10上
2018/01/15 Python
使用python实现希尔、计数、基数基础排序的代码
2019/12/25 Python
keras:model.compile损失函数的用法
2020/07/01 Python
CSS3改变浏览器滚动条样式
2019/01/04 HTML / CSS
纽约香氛品牌:NEST Fragrance
2018/10/15 全球购物
初三学生评语大全
2014/04/24 职场文书
2015小学五年级班主任工作总结
2015/05/21 职场文书
幼儿园新学期开学寄语
2015/05/27 职场文书
幽默导游词开场白
2015/05/29 职场文书
安全伴我行主题班会
2015/08/13 职场文书
OpenCV中resize函数插值算法的实现过程(五种)
2021/06/05 Python
Python测试框架pytest高阶用法全面详解
2022/06/01 Python