JavaScript 工厂模式和订阅模式
设计模式的好处:
- 代码规范
// 例如表单验证,两个 input ,一个用户名,一个密码
// 通常做法是
function checkUser(){
//.....
}
function checkPassword(){
//.....
}
// 问题:
// 这是两个全局对象,而这两个方法属于一个表单的验证
// 所以这应该是一个表单对象,起码应该这么写
// 对象封装,但是注意全局对象
var checkObj = {
checkUser: function() {
//.....
},
checkPassword: function() {
//.....
}
}
// 问题:
// 对象过多
// 解决:闭包
(function(){
//.....
})()
工厂模式
// ajax 为例
var xhr = new XMLHttpRequest(); // IE6不兼容XMLHttpRequest对象,需要使用ActiveXObject("Microsoft.XMLHTTP")
xhr.onreadystatechange = function(){
}
xhr.open();
xhr.send(null);
// 使用工厂模式
// 好处:低耦合,高内聚
var XMLHTTPFactory = function() {
var XMLHTTP = null;
if (window.XMLHttpRequest()){
XMLHTTP = new XMLHttpRequest();
} else {
XMLHTTP = new ActiveXObject("Microsoft.XMLHTTP");
}
return XMLHTTP;
}
// 使用
var xhr = XMLHTTPFactory();
订阅者模式
// 订阅者:买家
// 发布者:卖家
var showObj = {}; // 定义发布者
showObj.list = []; // 存储订阅者
// 增加订阅者,订阅消息
showObj.listen = function (fn) { // fn回调函数,输出你想输出的内容
showObj.list.push(fn);
}
showObj.trigger = function () {
for (var i = 0, fn; fn = this.list[i++];) {
fn.apply(this, arguments);
}
}
showObj.listen(function (color, size) {
console.log("颜色是" + color);
console.log("尺码是" + size);
})
showObj.listen(function (color, size) {
console.log("再次输出颜色是" + color);
console.log("再次输出尺码是" + size);
})
showObj.trigger("白色", 40);
showObj.trigger("黑色", 20);
// 你会发现输出了两遍,这是为什么呢?
// 原因就在于showObj.list.push(fn)
// 那么如何使不同的订阅者查看到属于自己的订阅呢
使用一个key区分
var showObj = {}; // 定义发布者
showObj.list = []; // 存储订阅者
// 增加订阅者,订阅消息
showObj.listen = function (key, fn) { // 在订阅的时候给一个标识
if (!this.list[key]) {
this.list[key] = [];
}
showObj.list[key].push(fn);
}
showObj.trigger = function () { // 发布的时候认识知道订阅的消息分别发布给谁
// 取到消息名称
var key = Array.prototype.shift.call(arguments);
// 对应的回调函数
var fns = this.list[key];
if (!fns || fns.length === 0) {
return;
}
for (var i = 0, fn; fn = fns[i++];) {
fn.apply(this, arguments);
}
}
showObj.listen("white", function (color, size) {
console.log("小爱同学订阅的颜色是" + color);
console.log("小爱同学订阅的尺码是" + size);
})
showObj.listen("black", function (color, size) {
console.log("小冰同学订阅的颜色是" + color);
console.log("小冰同学订阅的尺码是" + size);
})
showObj.trigger("white", "白色", 40);
showObj.trigger("black", "黑色", 20);
// 但是这样的写的话适用性太差,所以我们需要对其进行封装。
封装
var event = {
list: [],
listen: function (key, fn) { // 在订阅的时候给一个标识
if (!this.list[key]) {
this.list[key] = [];
}
this.list[key].push(fn);
},
trigger: function () { // 发布的时候认识知道订阅的消息分别发布给谁
// 取到消息名称
var key = Array.prototype.shift.call(arguments);
// 对应的回调函数
var fns = this.list[key];
if (!fns || fns.length === 0) {
return;
}
for (var i = 0, fn; fn = fns[i++];) {
fn.apply(this, arguments);
}
},
// 移除方法(取消订阅)
remove: function (key, fn) {
var fns = this.list[key];
// 没有订阅过
if (!fns) {
return false;
}
// 回调函数为空
if (!fn) {
fn && (fns.length = 0);
} else {
for (var i = fns.length - 1; i >= 0; i++) {
var _fn = fns[i];
if (_fn === fn) {
fns.splice(i, 1);//删除订阅者的回调函数
}
}
}
}
};
var initEvent = function (obj) {
for (var i in event) {
obj[i] = event[i]
}
}
var showObj = {};// 让任何一个普通对象都拥有发布订阅功能
initEvent(showObj);
showObj.listen("white", fn1 = function (color, size) {
console.log("小爱同学订阅的颜色是" + color);
console.log("小爱同学订阅的尺码是" + size);
})
showObj.listen("black", fn2 = function (color, size) {
console.log("小冰同学订阅的颜色是" + color);
console.log("小冰同学订阅的尺码是" + size);
})
showObj.trigger("white", "白色", 40);
showObj.trigger("black", "黑色", 20);
JavaScript 工厂模式和订阅模式的更多相关文章
- javascript中的发布订阅模式与观察者模式
这里了解一下JavaScript中的发布订阅模式和观察者模式,观察者模式是24种基础设计模式之一. 设计模式的背景 设计模式并非是软件开发的专业术语,实际上设计模式最早诞生于建筑学. 设计模式的定义是 ...
- Javascript中理解发布--订阅模式
Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 如何实现发布--订阅模式? 发布---订阅模式的代码封装 如何取消订阅事件? 全局--发布订阅对象代码封装 理解模块间通信 回到 ...
- [转] Javascript中理解发布--订阅模式
发布订阅模式介绍 发布---订阅模式又叫观察者模式,它定义了对象间的一种一对多的关系,让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时,所有依赖于它的对象都将得到通知. 现实生活中的发布- ...
- [转] JavaScript设计模式之发布-订阅模式(观察者模式)-Part1
<JavaScript设计模式与开发实践>读书笔记. 发布-订阅模式又叫观察者模式,它定义了对象之间的一种一对多的依赖关系.当一个对象的状态发生改变时,所有依赖它的对象都将得到通知. 例如 ...
- 【转】Javascript中理解发布--订阅模式
Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 发布---订阅模式又叫观察者模式,它定义了对象间的一种一对多的关系,让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时 ...
- 阶段5 3.微服务项目【学成在线】_day05 消息中间件RabbitMQ_8.RabbitMQ研究-工作模式-发布订阅模式-生产者
Publish/subscribe:发布订阅模式 发布订阅模式: 1.每个消费者监听自己的队列. 2.生产者将消息发给broker,由交换机将消息转发到绑定此交换机的每个队列,每个绑定交换机的队列都将 ...
- JavaScript设计模式(发布订阅模式)
发布—订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知.在JavaScript开发中,我们一般用事件模型来替代传统的发布—订阅模式 ...
- Javascript设计模式之发布-订阅模式
简介 发布-订阅模式又叫做观察者模式,他定义了一种一对多的依赖关系,即当一个对象的状态发生改变的时候,所有依赖他的对象都会得到通知. 回忆曾经 作为一名前端开发人员,给DOM节点绑定事件可是再频繁不过 ...
- javascript 自定义事件 发布-订阅 模式 Event
* javascript自定义事件 var myEvent = document.createEvent("Event"); myEvent.initEvent("myE ...
- 第五章 --- 关于Javascript 设计模式 之 发布-订阅模式
先来个最简单的 发布订阅模式 document.body.addEventListener('click',function(){ alert(123); }); document.body.clic ...
随机推荐
- 【Luogu】P2607骑士(基环树DP)
题目链接 这题……好吧我比着题解打的 题解连接 #include<cstring> #include<cstdio> #include<cstdlib> #incl ...
- 二进制<1>
Matrix67:位运算简介及实用技巧(一) 基础篇 什么是位运算? 程序中的所有数在计算机内存中都是以二进制的形式储存的.位运算说穿了,就是直接对整数在内存中的二进制位进行操作.比如,and运 ...
- NBOJv2——Problem 1037: Wormhole(map邻接表+优先队列SPFA)
Problem 1037: Wormhole Time Limits: 5000 MS Memory Limits: 200000 KB 64-bit interger IO format: ...
- 群论 - Group Theory
群的定义 若非空集合\(G\)和定义在\(G\)上的二元运算\(⋅\)构成的代数结构\((G,⋅)\),满足: 封闭性:\(\forall a,b\in G\),有\(a⋅b\in G\). 结合律: ...
- [暑假集训--数位dp]hdu5787 K-wolf Number
Alice thinks an integer x is a K-wolf number, if every K adjacent digits in decimal representation o ...
- python hashlib模块 logging模块 subprocess模块
一 hashlib模块 import hashlib md5=hashlib.md5() #可以传参,加盐处理 print(md5) md5.update(b'alex') #update参数必须是b ...
- 实验六 TLS协议报文解析
一.实验目的 1.访问一个https://....的网站,捕TLS包并分析报文序列. 2.分析连接建立的完整过程,如:TCP三次握手.SSL安全连接,使用TLS协议连接.协商过程,加密传送的状态.TC ...
- 小程序 之登录 wx.login()
小程序的登录关键在于使用wx.login()方法后,要到取到code值传到后台, 再用小程序平台本帐号生成的appid+addsecret+code去微信接口服务取得用户唯一标识后即可登录[注意:此步 ...
- python3:requests模块-写了一点
使用requests,它的七个主要方法,在这里只讲两个:get.post >>> import requests >>> r=requests.get(" ...
- mac 下删除xcode后使用git
1. http://blog.bobbyallen.me/2014/03/07/how-to-install-git-without-having-to-install-xcode-on-macosx ...