[设计模式] Javascript 之 观察者模式
观察者模式:定议
定义对象间的一种一对多的关系,当一个对象状态改变时 (一般称为被观察者),依赖于该对象的对象被通知,并更新;
观察者模式:说明
1. 观察者模式是行为模式,也被称为:发布-订阅模式、模型-视图模式、源-监听器模式、从属者模;
2. 面对象过程中观察者模式的组成:
1>. 抽象主题角色:这个角色里,定义维护了一份对观察者列表的管理集,一组用数组来存放,并定义了对一些基础的接口,比例用来添加跟删除观察者的方法;
2>. 具体主题角色:这个角色,对于与客户,具体业务状态数据交互,并做一定的处理,然后再通知各个观察者 更新自己;
抽象跟具体主题里的 一些常用的方法接口,如果 add|delete 或 notified方法,在哪个方法不是固定的; add跟delete也可以出现在 具体的主题角色里;
3>. 抽象观察者角色:为所有观察者定义一个统一的接口,这个接口叫更新接口;
4>. 具体观察者角色:实现抽象观察者角色的各自的更新方法;
3. 执行过程:

4. 观察者模式-结构图:

5. 场景实例描述:
1>. 比如说母亲通知孩子吃饭的例子,一个家里有一两个孩子,这两个小孩子有点调皮,喜欢乱跑,妈妈把饭煮好了,但是看不到小孩的身影,叫也没见小孩回应回来的,所以妈妈就在小孩身上装了个 通知设备,一到把饭煮好,妈妈就在一个通知设备上按个按钮,就可以小孩身上的设备上发出声音:‘饭煮好了,快点回来吃饭’,然后小孩就可以马上回来吃刚上桌温热的饭菜了;
2>. java的事件监听机制包括:事件源,事件监听器,事件对象;
事件监听器相当于观察者,观察者用于提供统一的更新方法;
事件源与事件对象相当于被观察者 (具体主题对象)
6. 观察者模式所应用到的原则: 对象的单一性质原则,开闭原则等;开闭原则所体现到的就是面对对象编码所提到要以接口来编程的原则,这样程序对象间就可以更好的复用及解耦;
7. 观察者模式主要组成: 被观察对象(目标对象, 具体对象, 主题), 观察者 (订阅者, 监听者), 事件(更新方法);
8. 当具体观察者对象的更新方法接收为普通类型数据,比如 string 时, 一般称为“推”模式;
当 更新方法传递的是,被观察者(具体主题对象)时,一般被称为“拉”模式;
源码实例
1. 主题对象:
function Subject() {
this.Observers = [];
}
Subject.prototype.add = function(observer) {
this.Observers.push(observer);
}
Subject.prototype.remove = function(observer) {
var me = this;
for (idx in me.Observers) {
if (me.Observers[idx] == observer) {
me.Observers[idx].splice(idx, 1);
break;
}
}
}
//推模式
Subject.prototype.notifyState = function(info) {
var me = this;
for (idx in me.Observers) {
me.Observers[idx].update(info)
}
}
//接模式
Subject.prototype.notifyObservers = function(subject) {
var me = this;
for (idx in me.Observers) {
me.Observers[idx].updateSubject(subject)
}
}
2. 具体主体对象
function ConcreteSubject() {
Subject.call(this);
}
ConcreteSubject.prototype.operate = function() {
var state = 'info';
this.notifyState(state);
this.notifyObservers(this);
}
3. 观察者对象A
function ConcreteObserverA() {
this.update = function(info) {
console.log('A Observer'+info);
}
this.updateSubject = function(subject) {
console.log('A Observer object');
}
}
4. 观察者对象B
function ConcreteObserverB() {
this.update = function(info) {
console.log('B Observer'+info);
}
this.updateSubject = function(subject) {
console.log('B Observer object');
}
}
5. 使用方法;
var subject = new ConcreteSubject(); var aobserver = new ConcreteObserverA();
var bobserver = new ConcreteObserverB(); subject.add(aobserver);
subject.add(bobserver); subject.operate();
其他说明
主题对象是可以多种不同存在的,就是上面的妈妈叫孩子吃饭例子,一个小区,一个小村庄会有多个的母亲,一个母亲下会有一个或几个的孩子;
母亲是被观察者,小孩们是观察者,他们在等待母亲主动推送消息通知他们去吃饭,但是小孩子回家的具体方式是不一样的,有的是马上跑回来,有的是慢慢吞吞回家去;
母亲是一个对象类,这个对象类当发生煮饭煮熟了,就会执行operate这个方法,去通知这小孩子的观察类对象,然后再更新自己回家去,在面向对象原则里,类要求功能单一职责,这有助于应用情况的扩展以及解耦;
[设计模式] Javascript 之 观察者模式的更多相关文章
- 设计模式 ( 十六 ) 观察者模式Observer(对象行为型)
设计模式 ( 十六 ) 观察者模式Observer(对象行为型) 1.概述 一些面向对象的编程方式,提供了一种构建对象间复杂网络互连的能力.当对象们连接在一起时,它们就可以相互提供服务和信息. 通常来 ...
- Java设计模式之《观察者模式》及应用场景
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6513651.html 观察者模式,又可以称之为发布-订阅模式,观察者,顾名思义,就是一个监 ...
- Java设计模式百例 - 观察者模式
观察者(Observer)模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,主体对象的状态变化会通知所有观察者对象.观察者模式又叫做发布-订阅(Publish/Subscribe ...
- [head first 设计模式]第二章 观察者模式
[head first 设计模式]第二章 观察者模式 假如我们有一个开发需求--建造一个气象观测站展示系统.需求方给我们提供了一个WeatherObject对象,能够自动获得最新的测量数据.而我们要建 ...
- 【读书笔记】读《JavaScript设计模式》之观察者模式
一.定义 在事件驱动的环境中,比如浏览器这种持续寻求用户关注的环境中,观察者模式(又名发布者-订阅者(publisher-subscripber)模式)是一种管理人与其任务之间的关系(确切地讲,是对象 ...
- [转] 浅析JavaScript设计模式——发布-订阅/观察者模式
前一段时间一直在写CSS3的文章 一直都没写设计模式 今天来写写大名鼎鼎观察者模式 先画张图 观察者模式的理解 我觉得还是发布-订阅模式的叫法更容易我们理解 (不过也有的书上认为它们是两种模式……) ...
- 前端中的设计模式 JavaScript
最近再准备秋招,然后顺便把过去空白的设计模式相关概念补一补,这些内容都是从<JavaScript设计模式与开发实践>一书中整理出来的 (1)单例模式 定义:保证一个类仅有一个实例,并提供一 ...
- Java设计模式10:观察者模式
观察者模式 观察者模式也叫作发布-订阅模式,也就是事件监听机制.观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,这个主题对象在状态上发生变化时,会通知所有观察者对象,使他 ...
- 大话设计模式C++版——观察者模式
观察者模式是一种类似于消息分发的模式,用于一个任务需要被多个对象监听的场景,或者成员对象需要反向通知类对象的情况,是一种很有用的设计模式. 这里以大话设计模式中的例子为例,办公室员工A.B.C在 ...
随机推荐
- CLR/.NET/C#/Visual Studio/ASP.NET各版本之间的关系(转)
由于这篇文章记录的是2015年7月,那时.net core还是叫做.net core 5 名词定义 下列这些名词,写.NET 的人一定都不陌生,但你是否有真正理解呢?如果看了我的摘要文字说明还无法理解 ...
- app 摇一摇功能
1.重写canBecomeFirstResponder ,并返回YES -(BOOL)canBecomeFirstResponder{ return YES; } 2.重写UIResponder的三个 ...
- HFSS使用记录
一.基本设置 1.Tools \ Options,各种基本设置 1.1 Tools \ Options \ HFSS Options-> Duplicate boundaries/mesh op ...
- java里面时间差比较
currentTime.before(this.getLastActivateTime(time))//返回true 或者false public Date getLastActivateTime(t ...
- MVC5-2 MVC的管道流与路由
自定义Modue与Hander 之前讲了管道流中的Module与Hndler.现在我们可以去自定义Module和Handler Module 其实很简单,一共需要三个步骤 定义一个类去继承IHttpM ...
- COGS 577 蝗灾
传送门 时间限制:2 s 内存限制:128 MB DESCRIPTION C国国土辽阔,地大物博......但是最近却在闹蝗灾..... 我们可以把C国国土当成一个W×W的矩阵,你会收到一些诸如(X, ...
- 使用dom4j解析XML文档
dom4j的包开源包,不属于JDK里面,在myeclipse中要单独导入在项目中,这里不累赘了 做这个过程,很慢,因为很多方法没用过不熟悉,自己得去查帮助文档,而且还得去试,因为没有中文版,英文翻译不 ...
- jquery selector 基础
转自:http://www.cnblogs.com/zwl12549/archive/2008/08/09/1264163.html query的这套选择符是比较帅气的,借用了XPath2.0和CSS ...
- maven的环境搭建
maven环境快速搭建 最近,开发中要用到maven,所以对maven进行了简单的学习. .关于maven是什么东东,请参考其它文章. ----------------准备工作------------ ...
- wifi-mac
//18:a6:f7:12:0b:8b //18:a6:f7:1e:a9:57 //18:a6:f7:1f:8e:69 //18:a6:f7:12:0b:9c //18:a6:f7:1f:cd:d4 ...