深入理解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 相关文章推荐
javascript常见操作汇总
Sep 03 Javascript
jquery动态加载js/css文件方法(自写小函数)
Oct 11 Javascript
JS实现的另类手风琴效果网页内容切换代码
Sep 08 Javascript
JS验证邮件地址格式方法小结
Dec 01 Javascript
JavaScript数组的一些奇葩行为
Jan 25 Javascript
浅谈jQuery 中的事件冒泡和阻止默认行为
May 28 Javascript
jQuery 常见小例汇总
Dec 14 Javascript
vue element-ui 绑定@keyup事件无效的解决方法
Mar 09 Javascript
AngularJS监听ng-repeat渲染完成的方法
Mar 20 Javascript
javascript 对象 与 prototype 原型用法实例分析
Nov 11 Javascript
Jquery让form表单异步提交代码实现
Nov 14 jQuery
JavaScript中作用域链的概念及用途讲解
Aug 06 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
YII Framework框架教程之国际化实现方法
2016/03/14 PHP
总结对比php中的多种序列化
2016/08/28 PHP
laravel 解决Eloquent ORM的save方法无法插入数据的问题
2019/10/21 PHP
jquery1.83 之前所有与异步列队相关的模块详细介绍
2012/11/13 Javascript
SOSO地图API使用(一)在地图上画圆实现思路与代码
2013/01/15 Javascript
jQuery使用ajaxSubmit()提交表单示例
2014/04/04 Javascript
jquery查找tr td 示例模拟
2014/05/08 Javascript
Jquery ui datepicker设置日期范围,如只能隔3天【实现代码】
2016/05/04 Javascript
获取input标签的所有属性的方法
2016/06/28 Javascript
js从数组中删除指定值(不是指定位置)的元素实现代码
2016/09/13 Javascript
jQuery autoComplete插件两种使用方式及动态改变参数值的方法详解
2016/10/24 Javascript
jQuery实现手机上输入后隐藏键盘功能
2017/01/04 Javascript
nodejs的压缩文件模块archiver用法示例
2017/01/18 NodeJs
javascript中BOM基础知识总结
2017/02/14 Javascript
vue-cli常用设置总结
2018/02/24 Javascript
支付宝小程序自定义弹窗dialog插件的实现代码
2018/11/30 Javascript
JavaScript实现单图片上传并预览功能
2019/09/30 Javascript
python字符串排序方法
2014/08/29 Python
Python中的多重装饰器
2015/04/11 Python
python使用range函数计算一组数和的方法
2015/05/07 Python
django session完成状态保持的方法
2018/11/27 Python
学生信息管理系统Python面向对象版
2019/01/30 Python
Python爬虫——爬取豆瓣电影Top250代码实例
2019/04/17 Python
解决pycharm运行程序出现卡住scanning files to index索引的问题
2019/06/27 Python
浅谈tensorflow之内存暴涨问题
2020/02/05 Python
Python面向对象魔法方法和单例模块代码实例
2020/03/25 Python
Pycharm生成可执行文件.exe的实现方法
2020/06/02 Python
详解Python openpyxl库的基本应用
2021/02/26 Python
党员个人思想汇报
2013/12/28 职场文书
驻村工作先进事迹
2014/08/14 职场文书
销售员工作检讨书(推荐篇)
2014/10/18 职场文书
天坛导游词
2015/02/02 职场文书
2015新生加入学生会自荐书
2015/03/24 职场文书
《狼牙山五壮士》读后感:宁死不屈,视死如归
2019/08/16 职场文书
如何用Laravel包含你自己的帮助函数
2021/05/27 PHP
如何解决springcloud feign 首次调用100%失败的问题
2021/06/23 Java/Android