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 相关文章推荐
屏蔽F1~F12的快捷键的js函数
May 06 Javascript
JavaScript实现GriwView单列全选(自写代码)
May 13 Javascript
基于javascript的JSON格式页面展示美化方法
Jul 02 Javascript
JS+CSS实现弹出全屏灰黑色透明遮罩效果的方法
Dec 20 Javascript
让你一句话理解闭包(简单易懂)
Jun 03 Javascript
基于Angular.js实现的触摸滑动动画实例代码
Feb 19 Javascript
jQuery实现元素的插入
Feb 27 Javascript
jQuery鼠标移动图片上实现放大效果
Jun 25 jQuery
Vue使用枚举类型实现HTML下拉框步骤详解
Feb 05 Javascript
详解使用vue-admin-template的优化历程
May 20 Javascript
微信公众号开发之微信支付代码记录的实现
Oct 16 Javascript
javascript异常处理实现原理详解
Feb 17 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
探讨:如何使用PhpDocumentor生成文档
2013/06/25 PHP
Codeigniter校验ip地址的方法
2015/03/21 PHP
php析构函数的简单使用说明
2015/08/24 PHP
Yii框架批量插入数据扩展类的简单实现方法
2017/05/23 PHP
PHP实现根据密码长度显示安全条
2017/07/04 PHP
浅谈PHP中pack、unpack的详细用法
2018/03/12 PHP
javascript 播放器 控制
2007/01/22 Javascript
javascript 模式设计之工厂模式详细说明
2010/05/10 Javascript
一样的table?不一样的table(可编辑状态table)
2012/09/19 Javascript
在jQuery中 常用的选择器介绍
2013/04/16 Javascript
Js Jquery创建一个弹出层可加载一个页面
2014/05/08 Javascript
jQuery中:eq()选择器用法实例
2014/12/29 Javascript
jQuery实现自动与手动切换的滚动新闻特效代码分享
2015/08/27 Javascript
JS实现自动定时切换的简洁网页选项卡效果
2015/10/13 Javascript
Angular表单验证实例详解
2016/10/20 Javascript
Centos6.8下Node.js安装教程
2017/05/12 Javascript
JS表单提交验证、input(type=number) 去三角 刷新验证码
2017/06/21 Javascript
js 公式编辑器 - 自定义匹配规则 - 带提示下拉框 - 动态获取光标像素坐标
2018/01/04 Javascript
vue2.0之多页面的开发的示例
2018/01/30 Javascript
vue实现后台管理权限系统及顶栏三级菜单显示功能
2019/06/19 Javascript
JS实现在线ps功能详解
2019/07/31 Javascript
[01:28:31]《加油DOTA》真人秀 第五期
2014/09/01 DOTA
python实现sublime3的less编译插件示例
2014/04/27 Python
在CentOS上配置Nginx+Gunicorn+Python+Flask环境的教程
2016/06/07 Python
浅谈pandas中shift和diff函数关系
2018/04/08 Python
使用python matploblib库绘制准确率,损失率折线图
2020/06/16 Python
新秀丽拉杆箱美国官方网站:Samsonite美国
2016/07/25 全球购物
精油和天然健康美容产品:Art Naturals
2018/01/27 全球购物
土木建筑学生自我评价
2014/01/14 职场文书
学校消防安全制度
2014/01/30 职场文书
教师节促销活动方案
2014/02/14 职场文书
2014年公务员思想汇报范文:全心全意为人民服务
2014/03/06 职场文书
工程项目经理岗位职责
2015/02/02 职场文书
运动会宣传稿50字
2015/07/23 职场文书
军事理论课感想
2015/08/11 职场文书
mysql的数据压缩性能对比详情
2021/11/07 MySQL