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代码
Nov 20 Javascript
formvalidator验证插件中有关ajax验证问题
Jan 04 Javascript
dreamweaver 8实现Jquery自动提示
Dec 04 Javascript
基于JavaScript实现瀑布流效果(循环渐近)
Jan 27 Javascript
实用又漂亮的BootstrapValidator表单验证插件
May 30 Javascript
Vue.js每天必学之组件与组件间的通信
Sep 08 Javascript
js实现单张图片平移切换效果
Oct 11 Javascript
分析JS单线程异步io回调的特性
Dec 01 Javascript
vue 实现数字滚动增加效果的实例代码
Jul 06 Javascript
vue监听input标签的value值方法
Aug 27 Javascript
解决vue动态为数据添加新属性遇到的问题
Sep 18 Javascript
Js参数RSA加密传输之jsencrypt.js的使用
Feb 07 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
实现树状结构的两种方法
2006/10/09 PHP
php实现的简单美国商品税计算函数
2015/07/13 PHP
3种php生成唯一id的方法
2015/11/23 PHP
PHP中key和current,next的联合运用实例分析
2016/03/29 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
php+mysql开发中的经验与常识小结
2019/03/25 PHP
去除链接虚线全面分析总结
2006/08/15 Javascript
使用ExtJS技术实现的拖动树结点
2010/08/05 Javascript
Jquery 模板数据绑定插件的使用方法详解
2013/07/08 Javascript
关于JavaScript的变量的数据类型的判断方法
2015/08/14 Javascript
jQuery实现div随意拖动的实例代码(通用代码)
2016/01/28 Javascript
功能强大的jquery.validate表单验证插件
2016/11/07 Javascript
解析NodeJs的调试方法
2016/12/11 NodeJs
js截取字符串功能的实现方法
2017/09/27 Javascript
详解webpack打包后如何调试的方法步骤
2018/11/07 Javascript
Vue中的循环及修改差值表达式的方法
2019/08/29 Javascript
python写的ARP攻击代码实例
2014/06/04 Python
python进阶教程之模块(module)介绍
2014/08/30 Python
python中Flask框架简单入门实例
2015/03/21 Python
Django发送html邮件的方法
2015/05/26 Python
用Python识别人脸,人种等各种信息
2019/07/15 Python
详解Python3定时器任务代码
2019/09/23 Python
Python中zipfile压缩文件模块的基本使用教程
2020/06/14 Python
一款纯css3制作的2015年元旦雪人动画特效教程
2014/12/29 HTML / CSS
中学实习教师自我鉴定
2013/12/12 职场文书
英语商务邀请函范文
2014/01/16 职场文书
写求职信有哪些注意事项
2014/05/08 职场文书
单位作风建设剖析材料
2014/10/11 职场文书
党员评议表自我评价范文
2014/10/20 职场文书
2015年企业新年寄语
2014/12/08 职场文书
2014年医务科工作总结
2014/12/18 职场文书
幼儿园教研工作总结2015
2015/05/12 职场文书
签约仪式致辞
2015/07/30 职场文书
初中同学会致辞
2015/08/01 职场文书
2016年秋季趣味运动会开幕词
2016/03/04 职场文书
CentOS7设置ssh服务以及端口修改方式
2022/12/24 Servers