NodeJS设计模式总结【单例模式,适配器模式,装饰模式,观察者模式】


Posted in NodeJs onSeptember 06, 2017

本文实例讲述了NodeJS设计模式。分享给大家供大家参考,具体如下:

1 . 单例模式

顾名思义,单例就是保证一个类只有一个实例,实现的方法是,先判断实例是否存在,如果存在则直接返回,若不存在,则创建实例对象,并将实例对象保存在静态变量中,当下次请求时,则可以直接返回这个对象实例,这就确保了一个类只有一个实例对象。举个例子吧~一间学校刚刚起建还没有图书馆,有的同学就向领导提意见:"hey! 哥们,能不能帮我们建一个图书馆? "(想要一个图书馆实例),然后领导说:"no problem啊!等我一下,马上建给你"(实例还没有建立,便创建一个)。几个月后,图书馆建好了~有位奇葩同学也想去图书馆,他却向领导提出要求: "hey! 哥们,我想去图书馆,能不能帮我建一个?"然后领导说: "no problem个头阿!那边已经建好了一个,你去那间不就可以了吗!"(当实例已经存在的时候,则直接返回已经创建的实例)

/*singleInstance.js*/
var _instance = null;//定义初始化_instance
module.exports = function(time){
   function Car(time){
     this.time = time;
   }
   this.getInstance = function(){
     if(_instance != null){
       return _instance;
     }else{
       return new Car(time);
     }
   }
}

2. 适配器模式

若将一个类的接口转换为客户希望的另外一个接口,适配器模式可以使原本由于接口不兼容而不能一起工作的那些类可以一起工作。举个例子吧~小明的老爸大明很爱喝白酒,但是呢喝酒又伤身,小明看到便不忍心,于是他想了方法:把白酒瓶子里面的酒倒掉,换成了白开水(重写内容)。大明看到还是那个酒瓶就没太在意(接口没有改变,只是内容改变了),一口气就把"酒"喝完了,还很高兴~(此处假设大明智商比较低..)。因此支配器是一个既不得罪他人,也能达到自己目的的一个好方法~下面是具体的实现方法

/*target.js*/
module.exports = function(){
  this.request = function(){//原接口
    console.log('Target::request');
  }
}
/*adapter.js*/
var util = require('util');
var Target = require('./target.js');
var Adaptee = require('./adaptee.js');
function Adapter(){
  Target.call(this);
  this.request = function(){//重写原接口
    var adapteeObj = new Adaptee();//重写的内容
    adapteeObj.specialRequest();
  }
}
util.inherits(Adapter, Target);//通过继承原模块, 获得原接口
module.exports = Adapter;

3. 装饰模式

装饰模式可以通过继承的方式,为一个基类对象扩展功能。举个例子吧~一颗圣诞树,一开始什么都没有。然后Amy看到之后往树上挂了几个饰品(扩展原来的基类),然后Billy路过之后,觉得它还差点什么,就把圣诞树拿过来(继承),然后也往上面放点其他饰品(继续扩展)。

/*Base.js*/
module.exports = function(){
  this.dosomething = function(){
   console.log("Nice to meet u.");
  }
}
/*Decorator.js*/
var util = require("util);
var Base = require('./Base');
function Decorator(){
  Base.call(this);
  this.dosomething = function(){
     Base.dosomething();
     console.log('I am a decorator');//拓展内容
  }
}
util.inherits(Decorator, Base);//继承
module.exports = Decorator;

4. 观察者模式

什么是观察者模式呢?举个例子吧~小狗同学和小熊同学同时喜欢上了班里可爱的小兔同学。小狗和小熊都会注意着小兔的一举一动,只有小兔有什么动静他们两个都会知道~相对而言呢,小狗和小熊就是小兔的"观察者",而小兔呢就是"被观察的对象"。比较重要的是:小兔发生的动静(某个函数),会同时通知到观察者小狗和小熊,让他们两个也会做出相应的反馈(各自的回调函数)

/*被观察者*/
module.exports = function(){
  var m_obserSet = [];//观察者列表
  var _self = this;
  this.addObser = function(observer){
    m_obserSet.push(observer);//添加观察者
  }
  this.doAction = function(){
    console.log("Observable do some action");
    _self.notifyAllObeser();
  }
  this.notifyAllObeser = function(){//发生动作
    for(var key in m_obserSet){//逐个通知观察者
      m_obserSet[key].update();//观察者执行回调
    }
  }
}

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

NodeJs 相关文章推荐
Nodejs极简入门教程(一):模块机制
Oct 25 NodeJs
nodejs中实现阻塞实例
Mar 24 NodeJs
nodejs调用cmd命令实现复制目录
May 04 NodeJs
nodejs创建web服务器之hello world程序
Aug 20 NodeJs
实例详解Nodejs 保存 payload 发送过来的文件
Jan 14 NodeJs
NodeJS基础API搭建服务器详细过程记录
Apr 01 NodeJs
nodejs操作mysql实现增删改查的实例
May 28 NodeJs
NodeJs通过async/await处理异步的方法
Oct 09 NodeJs
深入理解NodeJS 多进程和集群
Oct 17 NodeJs
Nodejs处理异常操作示例
Dec 25 NodeJs
独立部署小程序基于nodejs的服务器过程详解
Jun 24 NodeJs
5分钟教你用nodeJS手写一个mock数据服务器的方法
Sep 10 NodeJs
Nodejs进阶之服务端字符编解码和乱码处理
Sep 04 #NodeJs
Windows下使用Nodejs运行js的方法
Sep 02 #NodeJs
用nodejs实现json和jsonp服务的方法
Aug 25 #NodeJs
NodeJS收发GET和POST请求的示例代码
Aug 25 #NodeJs
Nodejs 和Session 原理及实战技巧小结
Aug 25 #NodeJs
Nodejs 复制文件/文件夹的方法
Aug 24 #NodeJs
使用Nodejs连接mongodb数据库的实现代码
Aug 21 #NodeJs
You might like
php设计模式  Command(命令模式)
2011/06/17 PHP
基于xcache的配置与使用详解
2013/06/18 PHP
PHP判断数据库中的记录是否存在的方法
2014/11/14 PHP
PHP生成图片缩略图类示例
2017/01/12 PHP
PHP数据对象映射模式实例分析
2019/03/29 PHP
document.documentElement && document.documentElement.scrollTop
2007/12/01 Javascript
js png图片(有含有透明)在IE6中为什么不透明了
2010/02/07 Javascript
Jquery知识点一 Jquery的ready和Dom的onload的区别
2011/01/15 Javascript
JS中的数组的sort方法使用示例
2014/01/22 Javascript
用js传递value默认值的示例代码
2014/09/11 Javascript
javascript学习笔记(四)function函数部分
2014/09/30 Javascript
jQuery鼠标事件汇总
2015/08/30 Javascript
基于JavaScript实现弹出框效果
2016/02/19 Javascript
vue.js绑定class和style样式(6)
2016/12/09 Javascript
Angular2中如何使用ngx-translate进行国际化
2017/05/21 Javascript
jquery操作ul的一些操作笔记整理(干货)
2017/08/31 jQuery
JavaScript循环遍历你会用哪些之小结篇
2018/09/28 Javascript
微信小程序开发之点击按钮退出小程序的实现方法
2019/04/26 Javascript
微信小程序wepy框架学习和使用心得详解
2019/05/24 Javascript
python入门之语句(if语句、while语句、for语句)
2015/01/19 Python
用Python实现读写锁的示例代码
2018/11/05 Python
Python逐行读取文件中内容的简单方法
2019/02/26 Python
Python 列表去重去除空字符的例子
2019/07/20 Python
python psutil模块使用方法解析
2019/08/01 Python
python读取tif图片时保留其16bit的编码格式实例
2020/01/13 Python
wxPython修改文本框颜色过程解析
2020/02/14 Python
HTML5 video循环播放多个视频的方法步骤
2020/08/06 HTML / CSS
优衣库英国官网:UNIQLO英国
2016/12/25 全球购物
街头时尚在线:JESSICABUURMAN
2019/06/16 全球购物
舞蹈比赛获奖感言
2014/02/04 职场文书
致长跑运动员加油稿
2014/02/20 职场文书
2015年实习单位评语
2015/03/25 职场文书
如何写一份具有法律效力的借款协议书?
2019/07/02 职场文书
导游词之云南省玉龙雪山
2019/12/19 职场文书
python元组打包和解包过程详解
2021/08/02 Python
div与span之间的区别与使用介绍
2021/12/06 HTML / CSS