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-TreeView父子联动效果保持节点状态一致
Aug 12 Javascript
JavaScript高级程序设计 事件学习笔记
Sep 10 Javascript
JQuery遍历json数组的3种方法
Nov 08 Javascript
JQuery动态添加和删除表格行的方法
Mar 09 Javascript
innerHTML属性,outerHTML属性,textContent属性,innerText属性区别详解
Mar 13 Javascript
jQuery 1.9.1源码分析系列(十)事件系统之主动触发事件和模拟冒泡处理
Nov 24 Javascript
AngularJS 过滤器(自带和自建)详解
Sep 19 Javascript
vue.js 中使用(...)运算符报错的解决方法
Aug 09 Javascript
原生JS实现的放大镜特效示例【测试可用】
Dec 08 Javascript
微信小程序iOS下拉白屏晃动问题解决方案
Oct 12 Javascript
浅谈layui 绑定form submit提交表单的注意事项
Oct 25 Javascript
写一个Vue loading 插件
Nov 09 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
相对路径转化成绝对路径
2007/04/10 PHP
基于AppServ,XAMPP,WAMP配置php.ini去掉警告信息(NOTICE)的方法详解
2013/05/07 PHP
php提示Warning:mysql_fetch_array() expects的解决方法
2014/12/16 PHP
9个经典的PHP代码片段分享
2014/12/18 PHP
php实现从上传文件创建缩略图的方法
2015/04/02 PHP
Laravel 5.3 学习笔记之 安装
2016/08/28 PHP
完美的php分页类
2017/10/24 PHP
PHP学习笔记之session
2018/05/06 PHP
jQuery 数据缓存data(name, value)详解及实现
2010/01/04 Javascript
面向对象继承实例(a如何继承b问题)(自写)
2013/07/01 Javascript
火狐textarea输入法的bug的触发及解决
2013/07/24 Javascript
JS调用CS里的带参方法实例
2013/08/01 Javascript
使用JQuery快速实现Tab的AJAX动态载入(实例讲解)
2013/12/11 Javascript
IE中document.createElement的iframe无法设置属性name的解决方法
2015/09/14 Javascript
JavaScript 数组中最大最小值
2016/06/05 Javascript
AngularJS表格详解及示例代码
2016/08/17 Javascript
JavaScript实现购物车基本功能
2017/07/21 Javascript
angular或者js怎么确定选中ul中的哪几个li
2017/08/16 Javascript
php main 与 iframe 相互通讯类(js+php同域/跨域)
2017/09/14 Javascript
node中间层实现文件上传功能
2018/06/11 Javascript
微信小程序自定义组件传值 页面和组件相互传数据操作示例
2019/05/05 Javascript
[03:12]完美世界DOTA2联赛PWL DAY6集锦
2020/11/05 DOTA
python从入门到精通(DAY 2)
2015/12/20 Python
使用PM2+nginx部署python项目的方法示例
2018/11/07 Python
Python numpy中矩阵的基本用法汇总
2019/02/12 Python
Java ExcutorService优雅关闭方式解析
2020/05/30 Python
英国优质家居用品网上品牌:URBANARA
2018/06/01 全球购物
正宗的日本零食和糖果订阅盒:Bokksu
2019/11/21 全球购物
实习教师自我鉴定
2013/12/12 职场文书
潘婷洗发水广告词
2014/03/14 职场文书
交通事故协议书范本
2014/11/18 职场文书
爱心捐款感谢信
2015/01/20 职场文书
个人培训总结
2015/03/05 职场文书
SQLServer2019 数据库的基本使用之图形化界面操作的实现
2021/04/08 SQL Server
Python序列化模块JSON与Pickle
2022/06/05 Python
Python可视化神器pyecharts绘制水球图
2022/07/07 Python