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中void(0)的具体含义解释
Feb 27 Javascript
jquery 防止表单重复提交代码
Jan 21 Javascript
详解javascript实现自定义事件
Jan 19 Javascript
jQuery增加与删除table列的方法
Mar 01 Javascript
实例详解jQuery的无new构建
Aug 02 Javascript
jquery自定义插件结合baiduTemplate.js实现异步刷新(附源码)
Dec 22 Javascript
Bootstrap下拉菜单Dropdowns的实现代码
Mar 17 Javascript
浅谈在koa2中实现页面渲染的全局数据
Oct 09 Javascript
JS封装的模仿qq右下角消息弹窗功能示例
Aug 22 Javascript
深入探讨JavaScript的最基本部分之执行上下文
Feb 12 Javascript
jQuery AJAX与jQuery事件的分析讲解
Feb 18 jQuery
p5.js实现动态图形临摹
Oct 23 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
谏山创故乡大分县日田市水坝将设立《进击的巨人》立艾伦、三笠以及阿尔敏的铜像!
2020/03/06 日漫
PHP中的超全局变量
2006/10/09 PHP
php把session写入数据库示例
2014/02/26 PHP
贴一个在Mozilla中常用的Javascript代码
2007/01/09 Javascript
jquery中的$(document).ready()与window.onload的区别
2009/11/18 Javascript
jquery获取input表单值的代码
2010/04/19 Javascript
Raphael带文本标签可拖动的图形实现代码
2013/02/20 Javascript
js点击button按钮跳转到另一个新页面
2014/10/10 Javascript
jQuery中用dom操作替代正则表达式
2014/12/29 Javascript
DOM基础教程之使用DOM设置文本框
2015/01/20 Javascript
JavaScript中Null与Undefined的区别解析
2015/06/30 Javascript
jquery遍历函数siblings()用法实例
2015/12/24 Javascript
常用js,css文件统一加载方法(推荐) 并在加载之后调用回调函数
2016/09/23 Javascript
基于Vuejs框架实现翻页组件
2020/06/29 Javascript
smartupload实现文件上传时获取表单数据(推荐)
2016/12/12 Javascript
JavaScript使用正则表达式获取全部分组内容的方法示例
2017/01/17 Javascript
nodejs操作mysql实现增删改查的实例
2017/05/28 NodeJs
微信小程序用户授权弹窗 拒绝时引导用户重新授权实现
2019/07/29 Javascript
微信小程序 云开发模糊查询实现解析
2019/09/02 Javascript
JS时间戳与日期格式互相转换的简单方法示例
2021/01/30 Javascript
Web服务器框架 Tornado简介
2014/07/16 Python
python判断一个集合是否为另一个集合的子集方法
2018/05/04 Python
Python实现的特征提取操作示例
2018/12/03 Python
python使用QQ邮箱实现自动发送邮件
2020/06/22 Python
纯css3实现走马灯效果
2014/12/26 HTML / CSS
Html5 new XMLHttpRequest()监听附件上传进度
2021/01/14 HTML / CSS
英国电器零售商:PRC Direct
2018/06/21 全球购物
C/C++程序员常见面试题二
2015/11/19 面试题
大学毕业感言
2014/01/10 职场文书
课堂教学改革实施方案
2014/03/17 职场文书
公司市场专员岗位职责
2014/06/29 职场文书
一份文言文检讨书
2014/09/13 职场文书
交通事故赔偿协议书
2014/10/16 职场文书
领导班子整改方案
2014/10/25 职场文书
详解Java实现设计模式之责任链模式
2021/06/23 Java/Android
为什么MySQL不建议使用SELECT *
2022/04/03 MySQL