学习javascript设计模式之中介者模式

1、中介者模式的作用就是解除对象与对象之间的紧耦合关系。增加一个中介者对象后,所有的相关对象都通过中介者来通信,而不是互相引用,所以当一个对象发生改变时,只需要通知中介对象即可。中介者使各对象之间耦合松散,而且可以独立的改变他们之间的交互。中介者模式使网状的多对多关系变成了相对简单的一对多关系。

<select id="colorselect">
		<option value="">请选择颜色</option>
		<option value="red">红色</option>
		<option value="blue">蓝色</option>
	</select>

	<select name="" id="memoryselect">
		<option value="">请选择大小</option>
		<option value="16G">16G</option>
		<option value="32G">32G</option>
	</select>

	请输入购买数量:
	<input type="text" id="numberInput" /><br/>

	您选择了颜色:
	<div id="colorInfo"></div><br />
	您选择了内存:
	<div id="memoryInfo"></div><br />
	您输入了数量:
	<div id="numberInfo"></div><br />

	<button id="nextBtn" disabled="true">请选择手机颜色和购买数量</button>
<script type="text/javascript">

	var colorselect = document.getElementById("colorselect");
	var memoryselect = document.getElementById("memoryselect");
	var numberInput = document.getElementById("numberInput");
	var colorInfo = document.getElementById("colorInfo");
	var memoryInfo = document.getElementById("memoryInfo");
	var numberInfo = document.getElementById("numberInfo");

	var goods = {

		"red|32G":3,
		"red|16G":0,
		"blue|32G":1,
		"blue|16G":6
	}

	var mediator = (function(obj){

			return {
				change:function(obj){

					var color = colorselect.value,
						memory = memoryselect.value;

					if(obj == colorselect){
						colorInfo.innerHTML = color;
					}else if(obj  == memoryselect){
						memoryInfo.innerHTML = memory;
					}

				}
			}
	})();

	colorselect.onchange = function(){
		mediator.change(this);
	}
	memoryselect.onchange = function(){
		mediator.change(this);
	}
	numberInput.oninput = function(){
		mediator.change(this);
	}
时间: 2024-08-01 07:29:29

学习javascript设计模式之中介者模式的相关文章

javascript设计模式之中介者模式

/* * 小游戏演示中介者模式 * Home 按键 1 * Guest 按键 0 * 半分钟内看谁按下的次数多 * * 参与的对象: * 玩家 * 计分板 * 中介者 * * 中介者模式使对象之间松耦合,提高了可维护性 */ // 玩家 var Player = function (name) { this.name = name; this.point = 0; }; Player.prototype.play = function () { this.point += 1; mediator

javascript设计模式(中介者模式)

中介者模式的作用就是解除对象与对象之间的紧耦合关系,它也称‘调停者’.所有的对象都通过中介者对象来通信,而不是相互引用,所以当一个对象发生改变时,只需要通知中介者即可. 如:机场的指挥塔,每架飞机都只需要和指挥塔通信即可,指挥塔知道每架飞机的飞行状况,可以安排所有起降时间,调整航线等 中介者模式符合迪米特法则,即最少知识原则,指一个对象应该尽可能少地了解另外的对象.如果对象之间的耦合性太高,则改变一个对象,会牵动很多对象,难于维护.当对象耦合很紧时,要修改一个对象而不影响其它的对象是很困难的.

javaScript 设计模式之中介者模式示例

飞机把注册信息放到铁塔里,发送数据到铁塔,报告其它的飞机一些信息. var feiji = function( name ){ this.name = name; } feiji.prototype.send = function(msg,to){ console.log(this.name+"发送了信息"); tatai.sned(msg,to); }; feiji.prototype.jieshou=function(msg){ console.log(this.name+&quo

设计模式之中介者模式(Mediator)摘录

23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于如何创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而一个对象创建型模式将实例化委托给另一个对象.创建型模式有两个不断出现的主旋律.第一,它们都将关于该系统使用哪些具体的类的信息封装起来.第二,它们隐藏了这些类的实例是如何被创建和放在一起的.整个系统关于这些对象所知道的是由抽象类所定义的接口.因此,创建型模式在什么被创建,谁创建它,它是怎样被创建的,以

设计模式之中介者模式20170731

行为型设计模式之中介者模式: 一.含义 用一个中介对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 同事角色与其他同时角色通信的时候,一定要通过中介者角色(中介者封装了各个同事类之间的逻辑关系) 二.代码说明 1.主要有两个角色 1)中介者角色 通过协调各同事角色实现协作行为,因此它必须依赖于各个同事角色. 2)同事角色 每一个同事角色都知道中介者角色,而且与其他的同事角色通信的时候,一定要通过中介者角色协作. 每个同事类的行为分

设计模式(中介者模式-对象去耦)

声明:本系列文章内容摘自<iOS设计模式> 中介者模式 用一个对象来封装一系列对象的交互方式.中介者使个对象不需要显式地相互调用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 何时使用中介者模式 1.对象间的交互虽定义明确然而非常复杂,导致椅子对象彼此相互依赖而且难以理解: 2.因为对象引用了许多其他对象并与其通信,导致对象难以复用: 3.想要制定一个分布在多个对象中的逻辑或行为,又不想生成太多子类. 举个例子 有三个视图,我们可能需要两两之间进行跳转,类比于公司内同时每两个人都有可能

【设计模式】——中介者模式

中介者模式(Mediator),用一个中介者对象来封装一系列的对象交互.中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变他们之间的交互. Colleague叫做抽象同事类,而ConcreteColleague是具体同事类,每个具体同事只知道自己的行为,而不了解其他同事类的情况,但它们却都认识中介者对象,Mediator是抽象中介者,定义了同事对象到中介者对象的接口,ConcreteMediator是具体中介者对象,实现抽象类的方法,它需要知道所有具体同事类,并从具体同事接

学习大话设计模式01_简单工厂模式(简易计算器)

1 /** 2 * 面向对象(运算类) 3 * 简易计算器 4 * @author Monica 5 * 6 */ 7 public class Operation { 8 private double numberA = 0; 9 private double numberB = 0; 10 11 //虚函数 12 public double GetResult() { 13 double result = 0; 14 return result; 15 } 16 17 public doub

折腾Java设计模式之中介者模式

博文原址:折腾Java设计模式之中介者模式 中介者模式 中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性.这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合,使代码易于维护.中介者模式属于行为型模式. 通俗点来讲就是提供一个中介平台,说到平台,那其实很容易联系到我们很熟悉的房地产中介.我们可以直接通过这个平台得到我们想要的信息,不用对象自身与其他对象交互. 买房子租房子就不需要去找房东,只需要在中介那里获取相应的×××信息.如下图那样,两方只