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远程获取网页源代码实例
Sep 05 Javascript
纯js实现无限空间大小的本地存储
Jun 18 Javascript
深入分析JSON编码格式提交表单数据
Jun 25 Javascript
JavaScript的jQuery库中ready方法的学习教程
Aug 14 Javascript
JS HTML5拖拽上传图片预览
Jul 18 Javascript
jQuery实现的多张图无缝滚动效果【测试可用】
Sep 12 Javascript
原生js实现密码输入框值的显示隐藏
Jul 17 Javascript
vue router使用query和params传参的使用和区别
Nov 13 Javascript
vue 优化CDN加速的方法示例
Sep 19 Javascript
Vue 实现点击空白处隐藏某节点的三种方式(指令、普通、遮罩)
Oct 23 Javascript
浅谈vue在html中出现{{}}的原因及解决方式
Nov 16 Javascript
js实现上传图片到服务器
Apr 11 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操作MongoDB时的整数问题及对策说明
2011/05/02 PHP
php mysql 判断update之后是否更新了的方法
2012/01/10 PHP
PHP基础知识介绍
2013/09/17 PHP
php将session放入memcached的设置方法
2014/02/14 PHP
php删除文本文件中重复行的方法
2015/04/28 PHP
深入理解PHP中的empty和isset函数
2016/05/26 PHP
javaScript 判断字符串是否为数字的简单方法
2009/07/25 Javascript
jQuery Select(单选) 模拟插件 V1.3.62 改进版
2010/07/17 Javascript
JQuery学习笔录 简单的JQuery
2012/04/09 Javascript
JS正则表达式获取分组内容的方法详解
2013/11/15 Javascript
鼠标悬停小图标显示大图标
2016/01/22 Javascript
JS实现六边形3D拖拽翻转效果的方法
2016/09/11 Javascript
Javascript之面向对象--封装
2016/12/02 Javascript
JS实现拖拽的方法分析
2016/12/20 Javascript
微信小程序 页面跳转和数据传递实例详解
2017/01/19 Javascript
详解Angular4中路由Router类的跳转navigate
2017/06/09 Javascript
webpack 2.x配置reactjs基本开发环境详解
2017/08/08 Javascript
bootstrap实现二级下拉菜单效果
2017/11/23 Javascript
Python实现删除当前目录下除当前脚本以外的文件和文件夹实例
2015/07/27 Python
python中的turtle库函数简单使用教程
2018/07/23 Python
Python中整数的缓存机制讲解
2019/02/16 Python
Python Scrapy框架第一个入门程序示例
2020/02/05 Python
Jupyter Notebook折叠输出的内容实例
2020/04/22 Python
Python tkinter之Bind(绑定事件)的使用示例
2021/02/05 Python
HTML5手机端弹出遮罩菜单特效代码
2016/01/27 HTML / CSS
荷兰在线钓鱼商店:Raven
2019/06/26 全球购物
群胜软件Java笔试题
2012/09/29 面试题
几道数据库的面试题或笔试题
2014/05/31 面试题
文员个人的求职信范文
2013/09/26 职场文书
电大毕业个人生自我鉴定
2014/03/26 职场文书
2014年党员公开承诺书范文
2014/03/28 职场文书
银行求职信范文
2014/05/26 职场文书
应聘教师求职信
2014/07/19 职场文书
写给医生的感谢信
2015/01/22 职场文书
电影焦裕禄观后感
2015/06/09 职场文书
2016年禁毒宣传活动总结
2016/04/05 职场文书