javascript设计模式 ? 观察者模式原理与用法实例分析


Posted in Javascript onApril 22, 2020

本文实例讲述了javascript设计模式 ? 观察者模式原理与用法。分享给大家供大家参考,具体如下:

介绍:前面我们针对系统内一对多,多对多的情况做了解决方案,是使用中介者模式,将所有关联关系交由中介者处理。这一节我们介绍另外一种解决一对多问题的设计模式:观察者模式
观察者模式是使用频率最高的设计模式之一,用于建立一种对象与对象之间的依赖关系。

定义:定义对象之间的之间的一种一对多依赖关系,使得每当一个对象状态发生改变时,其相关依赖对象皆得到通知并被自动更新。观察者模式的别名包括发布-订阅模式,模型-视图模式,监听模式或从属模式。观察者模式是一种对象行为型模式。

场景:我们使用观察者模式做一个进制转换的小demo

示例:

var Subject = function(){
  var obServer = [];
  var _state;
 
  this.getState = function(){
    return _state;
  }
  this.setState = function(state){
    _state = state;
    this.notifyAllObservers();
  }
  this.attach = function(ob){
    obServer.push(ob);
  }
  this.notifyAllObservers = function(){
    obServer.map(function(item){
      item.update();
    });
  }
}
 
var BinaryObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Binary String:' + _subject.getState().toString(2));
  }
}
 
var OctalObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Octal String:' + _subject.getState().toString(8));
  }
}
 
var HexaObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Hex String:' + _subject.getState().toString(16));
  }
}
 
var subject = new Subject();
 
new HexaObserver(subject);
new OctalObserver(subject);
new BinaryObserver(subject);
 
subject.setState(15);
// Hex String:f
// Octal String:17
// Binary String:1111

在这个例子里面Subject称为目标,它是被观察的对象,一个目标允许被多个观察者观察,这些观察者存放于obServer的数组中,当目标发生change时通知所有观察者。
BinaryObserver,OctalObserver,HexaObserver这三个类称为观察者,观察者将对目标的改变作出反应。在观察者中需要维护一个指向目标对象的引用。

观察者模式总结:

优点:
* 观察者模式可以实现表示层和数据逻辑层的分离,定义了稳定的消息更新传递机制。
* 观察者模式在观察目标和观察者者之间建立一个抽象的耦合。观察目标只需要维持一个抽象观察者的集合,无需了解其具体观察者。
* 观察者模式支持广播通信,观察目标会向所有已注册的观察者发送通知,简化了一对多系统的设计难度

缺点:
* 在存在大量观察者时,对所有观察者的通知会花大量时间
* 如果观察者和目标之间存在循环依赖,将会导致系统崩溃

适用场景:
* 系统中存在一个对象的改变将导致一个或多个其他对象也发生改变。
* 系统中存在大量依赖链,A影响B,B影响C,C影响D

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript高级程序设计 阅读笔记(七) ECMAScript中的语句
Feb 27 Javascript
document.write()及其输出内容的样式、位置控制
Aug 12 Javascript
js从Cookies里面取值的简单实现
Jun 30 Javascript
jquery实现仿JqueryUi可拖动的DIV实例
Jul 31 Javascript
Angular 根据 service 的状态更新 directive
Apr 03 Javascript
浅析jQuery 遍历函数,javascript中的each遍历
May 25 Javascript
vue.js学习之vue-cli定制脚手架详解
Jul 02 Javascript
使用重写url机制实现验证码换一张功能
Aug 01 Javascript
vue.js过滤器+ajax实现事件监听及后台php数据交互实例
May 22 Javascript
JS中min函数实例讲解
Feb 18 Javascript
小程序中canvas的drawImage方法参数使用详解
Jul 04 Javascript
JS中封装axios来管控api的2种方式
Sep 11 Javascript
javascript设计模式 ? 状态模式原理与用法实例分析
Apr 22 #Javascript
Vue computed 计算属性代码实例
Apr 22 #Javascript
js 解析 JSON 数据简单示例
Apr 21 #Javascript
react 原生实现头像滚动播放的示例
Apr 21 #Javascript
解决angular 使用原生拖拽页面卡顿及表单控件输入延迟问题
Apr 21 #Javascript
javascript设计模式 ? 策略模式原理与用法实例分析
Apr 21 #Javascript
javascript设计模式 ? 备忘录模式原理与用法实例分析
Apr 21 #Javascript
You might like
收音机指标测试方法及仪器
2021/03/01 无线电
使用PHP获取当前url路径的函数以及服务器变量
2013/06/29 PHP
php curl模拟post请求小实例
2013/11/13 PHP
php生成图片验证码-附五种验证码
2015/08/19 PHP
php实现表单多按钮提交action的处理方法
2015/10/24 PHP
PHP Class SoapClient not found解决方法
2018/01/20 PHP
jquery $.ajax各个事件执行顺序
2010/10/15 Javascript
jquery+css+ul模拟列表菜单具体实现思路
2013/04/15 Javascript
js中 关于undefined和null的区别介绍
2013/04/16 Javascript
浅谈Javascript 数组与字典
2015/01/29 Javascript
jQuery实现仿腾讯迷你首页选项卡效果代码
2015/09/17 Javascript
JS控制弹出悬浮窗口(一览画面)的实例代码
2016/05/30 Javascript
利用node.js搭建简单web服务器的方法教程
2017/02/20 Javascript
详解angular用$sce服务来过滤HTML标签
2017/04/11 Javascript
ES6新特性一: let和const命令详解
2017/04/20 Javascript
深入浅出webpack之externals的使用
2017/12/04 Javascript
Element实现表格分页数据选择+全选所有完善批量操作
2019/06/07 Javascript
使用imba.io框架得到比 vue 快50倍的性能基准
2019/06/17 Javascript
AutoJs实现刷宝短视频的思路详解
2020/05/22 Javascript
python: 自动安装缺失库文件的方法
2018/10/22 Python
Python中字典与恒等运算符的用法分析
2019/08/22 Python
Django实现celery定时任务过程解析
2020/04/21 Python
css3实现冲击波效果的示例代码
2018/01/11 HTML / CSS
韩国爱茉莉太平洋化妆品美国站:Amore Pacific US
2016/10/28 全球购物
ellesse美国官方商店:意大利高级运动服品牌
2019/10/29 全球购物
阿联酋优惠券服务:Living Kool
2019/12/12 全球购物
电信专业毕业生推荐信
2013/11/18 职场文书
领导证婚人证婚词
2014/01/13 职场文书
庆国庆国旗下讲话稿2014
2014/09/21 职场文书
2014市府办领导班子“四风问题”对照检查材料思想汇报
2014/09/24 职场文书
共产党员批评与自我批评
2014/10/15 职场文书
孕妇离婚协议书范本
2014/11/20 职场文书
2015年万圣节活动总结
2015/03/24 职场文书
汽车质检员岗位职责
2015/04/08 职场文书
Python中OpenCV实现简单车牌字符切割
2021/06/11 Python
MySQL生成千万测试数据以及遇到的问题
2022/08/05 MySQL