深入理解Node.js中通用基础设计模式


Posted in Javascript onSeptember 19, 2017

谈到设计模式,你可能会想到 singletons, observers(观察者) 或 factories(工厂方法)。本文不并专门探讨他们。只是探讨Node.JS一些基础模式的实现,像依赖注入或中间件。

什么是设计模式?

设计模式是用来解决一般的,普遍发生的问题,且可重复使用的解决方案。

Singletons (单例)

Singletons模式限制了“类”,只有一个实例。在Node.js的创建单例是非常简单的,比如下面这个require。

//area.js
var PI = Math.PI;
function circle (radius) { 
 return radius * radius * PI;
}
module.exports.circle = circle;

你引用多少次都没有关系;它将只存在一个单一的实例。

var areaCalc = require('./area');
console.log(areaCalc.circle(5));

由于 require 的这种实现,单例可能在NPM模块中最常见的Node.js设计模式。

Observers(观察者)

一个维护了侦听/观察列表的对象,当状态改变时会自动通知他们。为了实现观察者模式,EventEmitter就派上用场了。

// MyFancyObservable.js
var util = require('util'); 
var EventEmitter = require('events').EventEmitter;
function MyFancyObservable() { 
 EventEmitter.call(this);
}
util.inherits(MyFancyObservable, EventEmitter);

就是这个;我们实现了一个可观察的对象!为了用它,让我们添加一些方法吧。

MyFancyObservable.prototype.hello = function (name) { 
 this.emit('hello', name);
};

太好了,试试侦听并响应这个事件!

var MyFancyObservable = require('MyFancyObservable'); 
var observable = new MyFancyObservable();
observable.on('hello', function (name) { 
 console.log(name);
});
observable.hello('john');

Factories (工厂方法)

工厂模式是一种创建者模式,不需要我们使用构造函数,它提供用于创建对象的通用接口。这种模式可以用于生成创建过程非常复杂的对象。

function MyClass (options) { 
 this.options = options;
}
function create(options) { 
 // modify the options here if you want
 return new MyClass(options);
}
module.exports.create = create;

工厂可以让测试更简单,因为你可以在里面注入依赖关系。

Dependency Injection 依赖注入

依赖注入是将其中的一个或多个依赖(或服务)注入,或通过引用传递到从属对象的设计模式。

在这个例子中,我们将创建一个的usermodel它获取数据库的依赖。

function userModel (options) { 
 var db;
 if (!options.db) {
  throw new Error('Options.db is required');
 }
 db = options.db;
 return {
  create: function (done) {
   db.query('INSERT ...', done);
  }
 }
}
module.exports = userModel;

现在,我们利用它创建一个实例:

var db = require('./db');
var userModel = require('User')({ 
 db: db
});

它为什么有用呢?它使测试变得更容易 - 当你写单元测试时,你可以把假的数据库实例注入模型。

Middlewares/pipelines 中间件/管道

中间件是一个强大功能且简单的概念:一个功能单元的输出是下一个功能单元的输入。如果你用过Express那么你已经使用了这个模式。

我们看一看 Koa 是如何做的:

app.use = function(fn){ 
 this.middleware.push(fn);
 return this;
};

所以基本上,当你添加一个中间件时,它只是被压入一个中间件队列中。但是当一个请求到达这个服务器会发生什么?

var i = middleware.length; 
while (i--) { 
 next = middleware[i].call(this, next);
}

没什么神奇的 - 你的中间件被一个接着一个调用了。

Streams

你可以把流作为特殊的管道。他比较适合处理大量数据流,即他们是字节,而不是对象。

process.stdin.on('readable', function () { 
  var buf = process.stdin.read(3);
  console.dir(buf);
  process.stdin.read(0);
});

总结

以上所述是小编给大家介绍的Node.js中通用基础设计模式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Jquery中显示隐藏的实现代码分析
Jul 26 Javascript
JQuery制作的放大效果的popup对话框(未添加任何jquery plugin)分享
Apr 28 Javascript
javascript实现手机震动API代码
Aug 05 Javascript
JavaScript实现99乘法表及隔行变色实例代码
Feb 24 Javascript
举例讲解如何判断JavaScript中对象的类型
Apr 22 Javascript
js+html5实现canvas绘制椭圆形图案的方法
May 21 Javascript
微信小程序 wx.uploadFile无法上传解决办法
Dec 14 Javascript
JS实现最简单的冒泡排序算法
Feb 15 Javascript
详解使用Vue Router导航钩子与Vuex来实现后退状态保存
Sep 11 Javascript
Angular入口组件(entry component)与声明式组件的区别详解
Apr 09 Javascript
使用 vue-i18n 切换中英文效果
May 23 Javascript
vue定义全局变量和全局方法的方法示例
Aug 01 Javascript
微信小程序媒体组件详解(视频,音乐,图片)
Sep 19 #Javascript
Javascript中将变量转换为字符串的三种方法
Sep 19 #Javascript
详解JS中的this、apply、call、bind(经典面试题)
Sep 19 #Javascript
JavaScript 中的 this 简单规则
Sep 19 #Javascript
在 Node.js 中使用原生 ES 模块方法解析
Sep 19 #Javascript
Webpack 服务器端代码打包的示例代码
Sep 19 #Javascript
原生js中ajax访问的实例详解
Sep 19 #Javascript
You might like
暴雪前总裁遗憾:没尽早追赶Dota 取消星际争霸幽灵
2020/03/08 星际争霸
自己动手做一个SQL解释器
2006/10/09 PHP
PHP+Memcache实现wordpress访问总数统计(非插件)
2014/07/04 PHP
php判断对象是派生自哪个类的方法
2015/06/20 PHP
PHP批量去除BOM头内容信息代码
2016/03/11 PHP
js中的escape及unescape函数的php实现代码
2007/09/04 Javascript
在JQuery dialog里的服务器控件 事件失效问题
2010/12/08 Javascript
js通过googleAIP翻译PHP系统的语言配置的实现代码
2011/10/17 Javascript
web的各种前端打印方法之jquery打印插件PrintArea实现网页打印
2013/01/09 Javascript
基于SVG的web页面图形绘制API介绍及编程演示
2013/06/28 Javascript
Flex通过JS获取客户端IP和计算机名的实例代码
2013/11/21 Javascript
jquery查找tr td 示例模拟
2014/05/08 Javascript
关于JavaScript中name的意义冲突示例介绍
2014/05/29 Javascript
js实现跨域的几种方法汇总(图片ping、JSONP和CORS)
2015/10/25 Javascript
javascript小数精度丢失的完美解决方法
2016/05/31 Javascript
js实现表格筛选功能
2017/01/18 Javascript
Layui给数据表格动态添加一行并跳转到添加行所在页的方法
2018/08/20 Javascript
vue中img src 动态加载本地json的图片路径写法
2019/04/25 Javascript
vue倒计时刷新页面不会从头开始的解决方法
2020/03/03 Javascript
Vue2.0 $set()的正确使用详解
2020/07/28 Javascript
解决vue watch数据的方法被调用了两次的问题
2020/11/07 Javascript
[06:40]2014DOTA2西雅图国际邀请赛 DK战队巡礼
2014/07/07 DOTA
Python实现读取txt文件并转换为excel的方法示例
2018/05/17 Python
Python实现爬虫抓取与读写、追加到excel文件操作示例
2018/06/27 Python
Python框架Flask的基本数据库操作方法分析
2018/07/13 Python
关于Keras Dense层整理
2020/05/21 Python
详解Python设计模式之策略模式
2020/06/15 Python
HTML5 video视频字幕的使用和制作方法
2018/05/03 HTML / CSS
Tory Burch美国官方网站:美国时尚生活品牌
2016/08/01 全球购物
bonprix匈牙利:女士、男士和儿童服装
2019/07/19 全球购物
迟到检讨书800字
2014/01/13 职场文书
自习课吵闹检讨书范文
2014/09/26 职场文书
表扬通报怎么写
2015/01/16 职场文书
余世维讲座观后感
2015/06/11 职场文书
Redis IP地址的绑定的实现
2021/05/08 Redis
Win11查看设备管理器
2022/04/19 数码科技