设计模式的好处:

  1. 代码规范
// 例如表单验证,两个 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 工厂模式和订阅模式的更多相关文章

  1. javascript中的发布订阅模式与观察者模式

    这里了解一下JavaScript中的发布订阅模式和观察者模式,观察者模式是24种基础设计模式之一. 设计模式的背景 设计模式并非是软件开发的专业术语,实际上设计模式最早诞生于建筑学. 设计模式的定义是 ...

  2. Javascript中理解发布--订阅模式

    Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 如何实现发布--订阅模式? 发布---订阅模式的代码封装 如何取消订阅事件? 全局--发布订阅对象代码封装 理解模块间通信 回到 ...

  3. [转] Javascript中理解发布--订阅模式

    发布订阅模式介绍 发布---订阅模式又叫观察者模式,它定义了对象间的一种一对多的关系,让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时,所有依赖于它的对象都将得到通知. 现实生活中的发布- ...

  4. [转] JavaScript设计模式之发布-订阅模式(观察者模式)-Part1

    <JavaScript设计模式与开发实践>读书笔记. 发布-订阅模式又叫观察者模式,它定义了对象之间的一种一对多的依赖关系.当一个对象的状态发生改变时,所有依赖它的对象都将得到通知. 例如 ...

  5. 【转】Javascript中理解发布--订阅模式

    Javascript中理解发布--订阅模式 阅读目录 发布订阅模式介绍 发布---订阅模式又叫观察者模式,它定义了对象间的一种一对多的关系,让多个观察者对象同时监听某一个主题对象,当一个对象发生改变时 ...

  6. 阶段5 3.微服务项目【学成在线】_day05 消息中间件RabbitMQ_8.RabbitMQ研究-工作模式-发布订阅模式-生产者

    Publish/subscribe:发布订阅模式 发布订阅模式: 1.每个消费者监听自己的队列. 2.生产者将消息发给broker,由交换机将消息转发到绑定此交换机的每个队列,每个绑定交换机的队列都将 ...

  7. JavaScript设计模式(发布订阅模式)

    发布—订阅模式又叫观察者模式,它定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都将得到通知.在JavaScript开发中,我们一般用事件模型来替代传统的发布—订阅模式 ...

  8. Javascript设计模式之发布-订阅模式

    简介 发布-订阅模式又叫做观察者模式,他定义了一种一对多的依赖关系,即当一个对象的状态发生改变的时候,所有依赖他的对象都会得到通知. 回忆曾经 作为一名前端开发人员,给DOM节点绑定事件可是再频繁不过 ...

  9. javascript 自定义事件 发布-订阅 模式 Event

    * javascript自定义事件 var myEvent = document.createEvent("Event"); myEvent.initEvent("myE ...

  10. 第五章 --- 关于Javascript 设计模式 之 发布-订阅模式

    先来个最简单的 发布订阅模式 document.body.addEventListener('click',function(){ alert(123); }); document.body.clic ...

随机推荐

  1. 关于ida pro的插件keypatch

    关于ida pro的插件keypatch 来源 https://blog.csdn.net/fjh658/article/details/52268907 关于ida pro的牛逼插件keypatch ...

  2. Mysql 数值类型

    Mysql数值类型 整数型 小数型(浮点数) 日期时间型

  3. 多态Poly中的向上/下转型 Upcast/Downcast

    [参考资料]马克-to-win java中多态polymorphism,向上转型和动态方法调度有什么用? java中什么叫多态,动态方法调度(dynamic method dispatch)? jav ...

  4. AIX 常用命令 第一步(uname,lspv)

    如何知道自己在运行单处理器还是多处理器内核? /unix 是指向已启动内核的符号链接.要了解正在运行什么内核模式,可输入 ls -l /unix 并查看 /unix 链接到什么文件.下面是 ls -l ...

  5. 常用的Java基本代码汇总

    1.字符串和整型的相互转换 String a= String.valueOf(2); int i = Integer.parseInt(a); 2. 向文件末尾添加内容 BufferedWriter ...

  6. 洛谷 [P2887] 防晒霜

    贪心 首先以 miSPF 为关键字降序排列,然后对于每一头奶牛寻找满足范围的 SPF 值最大的防晒霜用, 我们发现,因为已经按最小值降序排列,所以对于下界来说若当前奶牛满足,之后的奶牛肯定满足,对上界 ...

  7. TroubleShoot: SharePoint 2013: ExecuteOrDelayUntilScriptLoaded 页面发布后不执行的问题

    SharePoint 2010 中的ExecuteOrDelayUntilScriptLoaded,在2013 中使用时没有效果的问题. Example: SharePoint 2013 Code: ...

  8. Codevs 数字三角形 问题合集

    1220 数字三角形 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 如图所示的数字三角形,从顶部出发,在每一结点可以选择向左走或得 ...

  9. 【NOIP2016】愤怒的小鸟(状压DP)

    题意: Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可以用它向第一象限发射一只红色的小鸟,小鸟们的飞行轨迹均为形如 ...

  10. MSB与LSB Big Endian Little Endian

    Most Significant Bit, Last(Least) Significant Bit 最高有效位(MSB) 指二进制中最高值的比特.在16比特的数字音频中,其第1个比特便对16bit的字 ...