《javascript设计模式与开发实践》阅读笔记(14)—— 中介者模式
中介者模式
数个对象之间的通信全部委托一个中介者完成。适用于对象之间互相引用,关系错综复杂的情况。
什么情况下需要使用中介者模式
对象较多,且对象间会相互引用,当一个对象的某个状态改变时,得通知其他对象。形象点的例子,比如说团队游戏,每个对象之间都有关系,不是队友就是敌人,当一个对象死亡就得通知其他对象,当一队全部死亡,就得宣布另一队胜利。假设不用中介者模式,那任何一个对象死亡时,必须通知所有对象,而且得遍历一遍队友是否都已经死亡。又比如火车的线路调度,如果不通过中介者,你让火车之间彼此相互确认位置,然后分配速度,确保线路畅通,显然也是不现实的。
总结来看,就是当对象很多,且一个对象的状态对于最终结果和其他对象都是有意义的时候,比较适用中介者。这里的状态可以理解为属性。
或者说的形象一点,当需要整体调度的时候,就应该使用中介者模式。无论是调度火车线路还是管理游戏玩家,都需要一个信息的管理者。
怎么实现中介者模式
中介者模式可以响应对象信息,并且对具体对象做出安排。典型的观察者模式的需求,所以可以使用观察者模式来完成。
或者也可以让中介者提供具体的接口,对象通过接口和中介者交互。
具体例子
MVC框架,其中C(控制器)就是 M(模型)和 V(视图)的中介者。
优缺点
优点:1、降低了类的复杂度,将一对多转化成了一对一。 2、各个类之间的解耦。
缺点:中介者会庞大,变得复杂难以维护。
代码例子
玩家组队进行游戏,互相标记为队友或者是敌人,死亡一个敌人,提示死亡,当一队全部阵亡,宣布另外一队获胜。
var player=function(name,teamcolor){ //玩家类
this.name=name;
this.teamcolor=teamcolor;
} player.prototype.win=function(){
console.log( this.teamcolor+"队 "+this.name+" win" );
} player.prototype.die=function(){
control.playerdie(this); //control为中介对象
} var createPlayer=function(name,teamcolor){ //玩家工厂,新建一个工厂需要做两件事情,一个是创造这个对象,第二个是通知中介者
var newPlayer=new player(name,teamcolor);
control.addplayer(newPlayer); return newPlayer;
} var control=(function(){
var players={}; // 储存玩家
var handler={}; //添加具体方法的对象 handler.addplayer=function( player ){
var teamcolor=player.teamcolor;
players[teamcolor]=players[teamcolor] || []; //如果存在相应队伍数组就返回,否则创建一个新的数组 players[teamcolor].push( player );
} handler.playerdie=function( player ){
var death_all=true; //判断器
player.state="death";
console.log( player.teamcolor+"队 "+player.name+"死亡" );
var teamcolor=player.teamcolor;
for(var i=0,per;per=players[teamcolor][i++];){
if( per.state!="death" ){
death_all=false;
break;
}
} if ( death_all ){
for (var color in players){
if( color!=teamcolor){
for(var i=0,people;people=players[color][i++]; ){
people.win();
}
}
}
} } return handler;
})(); var aaa=new createPlayer("王蛋蛋","红");
var bbb=new createPlayer("李蛋蛋","红");
var ccc=new createPlayer("赵蛋蛋","红"); var en1=new createPlayer("李小花","蓝");
var en2=new createPlayer("王小草","蓝");
var en3=new createPlayer("李大白","蓝"); en1.die();
bbb.die();
aaa.die();
en2.die();
ccc.die(); /*执行结果*/
// 蓝队 李小花死亡
// 红队 李蛋蛋死亡
// 红队 王蛋蛋死亡
// 蓝队 王小草死亡
// 红队 赵蛋蛋死亡
// 蓝队 李小花 win
// 蓝队 王小草 win
// 蓝队 李大白 win
《javascript设计模式与开发实践》阅读笔记(14)—— 中介者模式的更多相关文章
- javascript设计模式与开发实践阅读笔记(4)——单例模式
定义 单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点. 具体来说,就是保证有些对象有且只有一个,比如线程池.全局缓存.浏览器中的window 对象等.在js中单例模式用途很广,比如登录 ...
- javascript设计模式与开发实践阅读笔记(8)——观察者模式
发布-订阅模式,也叫观察者模式:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知. 在JavaScript开发中,我们一般用事件模型来替代传统的观察者模式. ...
- javascript设计模式与开发实践阅读笔记(7)——迭代器模式
迭代器模式:指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示. 迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也可以按顺 ...
- javascript设计模式与开发实践阅读笔记(6)——代理模式
代理模式:是为一个对象提供一个代用品或占位符,以便控制对它的访问. 代理模式的关键是,当客户不方便直接访问一个对象或者不满足需要的时候,提供一个替身对象来控制对这个对象的访问,客户实际上访问的是替身对 ...
- javascript设计模式与开发实践阅读笔记(5)——策略模式
策略模式:定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换. 我的理解就是把各种方法封装成函数,同时存在一个可以调用这些方法的公共函数.这样做的好处是可以消化掉内部的分支判断,使代码效率 ...
- javascript设计模式与开发实践阅读笔记(9)——命令模式
命令模式:有时候需要向某些对象发送请求,但是并不知道请求的接收者是谁,也不知道被请求的操作是什么,此时希望用一种松耦合的方式来设计软件,使得请求发送者和请求接收者能够消除彼此之间的耦合关系. 说法很复 ...
- javascript设计模式与开发实践阅读笔记(11)—— 模板方法模式
模板方法模式: 由两部分结构组成,第一部分是抽象父类,第二部分是具体的实现子类.通常在抽象父类中封装了子类的算法框架,包括实现一些公共方法以及封装子类中所有方法的执行顺序.子类通过继承这个抽象类,也继 ...
- JavaScript设计模式与开发实践——读书笔记1.高阶函数(上)
说来惭愧,4个多月未更新了.4月份以后就开始忙起来了,论文.毕设.毕业旅行等七七八八的事情占据了很多时间,毕业之后开始忙碌的工作,这期间一直想写博客,但是一直没能静下心写.这段时间在看<Java ...
- 《JavaScript设计模式与开发实践》笔记第八章 发布-订阅模式
第八章 发布-订阅模式 发布-订阅模式描述 发布-订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知. 发布-订阅模式可以广泛应用于 ...
- JavaScript设计模式与开发实践——读书笔记1.高阶函数(下)
上部分主要介绍高阶函数的常见形式,本部分将着重介绍高阶函数的高级应用. 1.currying currying指的是函数柯里化,又称部分求值.一个currying的函数会先接受一些参数,但不立即求值, ...
随机推荐
- 关系型数据库工作原理-数据库整体框架(翻译自Coding-Geek文章)
本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-data ...
- angular2 实现的小项目
之前根据官网的demo做了一个小例子,将的都比较基本,为了更好的提高对angular的认知,又做了一个小例子,目前还不完善.主要有路由,http,组件之间的通信,服务等基本知识. 项目地址:https ...
- angular路由详解四(子路由)
子路由是相对路由 路由配置部分: 主要是children const routes: Routes = [ {path:'home', component: HomeComponent, childr ...
- Python上下文管理器
在Python中让自己创建的函数.类.对象支持with语句,就实现了上线文管理协议.我们经常使用with open(file, "a+") as f:这样的语句,无需手动调用f.c ...
- vue小demo易错点总结
1.在使用<transiton>添加过渡效果时,对应的标签需使用<router-link>,否则,transition不会达到应有的效果. 2.在路由文件里获取根实例时,需通过 ...
- [ZJOI2007] 矩阵游戏
Description 小Q是一个非常聪明的孩子,除了国际象棋,他还很喜欢玩一个电脑益智游戏――矩阵游戏.矩阵游戏在一个N*N黑白方阵进行(如同国际象棋一般,只是颜色是随意的).每次可以对该矩阵进行两 ...
- 001-List,数组,Set,Map属性的映射
hibernate.cfg.xml: <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configur ...
- 前端的UI设计与交互之字体篇
跨平台的字体设定,力求在各个操作系统下都有最佳展示效果.字体是界面设计中最重要的基本构成之一,用户通过文本来消化内容和完成工作,优雅的字体将大大提升用户的阅读体验及工作效率.在满足不同终端始终保持良好 ...
- 机器学习(1) - TensorflowSharp 简单使用与KNN识别MNIST流程
机器学习是时下非常流行的话题,而Tensorflow是机器学习中最有名的工具包.TensorflowSharp是Tensorflow的C#语言表述.本文会对TensorflowSharp的使用进行一个 ...
- Spring事务管理—aop:pointcut expression解析(转)
本文转载自: http://hane00.blog.163.com/blog/static/160061522011427473965/ 先来看看这个spring的配置文件的配置: <!-- 事 ...