Node.js下自定义错误类型详解


Posted in Javascript onOctober 17, 2016

前言

一般来说,很少人会考虑如何处理应用产生的错误的策略,调试的过程中,简单地利用console.log(‘error')定位错误,基本够用了,通过留下这些调试信息,能够为我们以后的调试过程中升了不少时间,提高了维护性。所以错误提示非常重要。同时,也会带来一些比较糟糕用法。最近的项目里就用到了自定义错误类型,觉得有必要深入了解一下,所以就写了这篇文章,方便自己和有需要的大家在需要的时候查阅。

Subclassing Error

首先我们可以定义一个 Error 的子类。通过 Object.create util.inherits 很容易实现:

var assert = require('assert');
var util = require('util');

function NotFound(msg){
 Error.call(this);
 this.message = msg;
}
util.inherits(NotFound, Error);
var error = new NotFound('not found');
assert(error.message);
assert(error instanceof NotFound);
assert(error instanceof Error);
assert.equal(error instanceof RangeError, false);

可以通过 instanceof 来检查错误类型,根据类型进行不同的处理。

上面的代码设置了自带的message, 并且 error NotFound Error 的一个实例, 但是不是 RangeError

如果用了 express 框架, 就能设置其他的 properties error 变得更有用。

比方说当处理一个HTTP的错误时, 就可以写成这样:

function NotFound(msg) {
 Error.call(this);
 this.message = msg;
 this.statusCode = 404;
}

现在就已经可以通过错误处理的中间件来处理错误信息:

app.use(function(err, req, res, next) {
 console.error(err.stack);

 if (!err.statusCode || err.statusCode === 500) {
 emails.error({ err: err, req: req });
 }

 res.send(err.statusCode || 500, err.message);
});

这会发送HTTP的状态码给浏览器, 当 err statusCode 未设置或者等于 500 的时候, 就通过邮件来发送这个错误。这样就能排除那些 404, 401, 403等等的错误。

读取 console.error(err.stack) 事实上并不会像预期那样工作,像 node, chrome 基于 V8 的可以使用 Error.captureStackTrace(this, arguments.callee) 的错误构造函数来进行堆栈跟踪。

var NotFound = function(msg) {
 Error.call(this);
 Error.captureStackTrace(this, arguments.callee);
 this.message = msg || 'Not Found';
 this.statusCode = 404;
 this.name = "notFound"
}
util.inherits(NotFound, Error);

export.NotFoundError = NotFound;

当然我们还可以将上面这个创建的抽象错误类型扩展到其他自定义错误中:

var notFountError = require('./error').NotFountError; 
var UserNotFound = function(msg){
 this.constructor.super_(msg);
}

util.inherits(UserNotFound, notFoundError);

总结

以上就是Node.js下自定义错误类型的全部内容,希望本文的内容对大家学习或者使用Node.js能有一定的帮助,如果有疑问大家可以留言交流。谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
ASP中进行HTML数据及JS数据编码函数
Nov 11 Javascript
Dom操作之兼容技巧分享
Sep 20 Javascript
Extjs Gird 支持中文拼音排序实现代码
Apr 15 Javascript
jQuery实现炫酷的鼠标轨迹特效
Feb 01 Javascript
jQuery实现简单倒计时功能的方法
Jul 04 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
Oct 10 Javascript
使用node.js中的Buffer类处理二进制数据的方法
Nov 26 Javascript
基于vue实现swipe轮播组件实例代码
May 24 Javascript
解决webpack+Vue引入iView找不到字体文件的问题
Sep 28 Javascript
用Object.prototype.toString.call(obj)检测对象类型原因分析
Oct 11 Javascript
简单了解JavaScript arguement原理及作用
May 28 Javascript
解决vue侦听器watch,调用this时出现undefined的问题
Oct 30 Javascript
js HTML5多媒体影音播放
Oct 17 #Javascript
基于JavaScript实现前端文件的断点续传
Oct 17 #Javascript
js html5 css俄罗斯方块游戏再现
Oct 17 #Javascript
Node.js包管理器Yarn的入门介绍与安装
Oct 17 #Javascript
深入理解JS实现快速排序和去重
Oct 17 #Javascript
JavaScript中关键字 in 的使用方法详解
Oct 17 #Javascript
Angular 2应用的8个主要构造块有哪些
Oct 17 #Javascript
You might like
深入了解php4(2)--重访过去
2006/10/09 PHP
php打造智能化的柱状图程序,用于报表等
2015/06/19 PHP
php超快高效率统计大文件行数
2015/07/05 PHP
php中switch语句用法详解
2015/08/17 PHP
PHP开发中常用的十个代码样例
2016/02/02 PHP
php生成mysql的数据字典
2016/07/07 PHP
PHP微商城开源代码实例
2019/03/27 PHP
Prototype 学习 工具函数学习($A方法)
2009/07/12 Javascript
数组Array进行原型prototype扩展后带来的for in遍历问题
2010/02/07 Javascript
JS实现self的resend
2010/07/22 Javascript
js改变鼠标的形状和样式的方法
2014/03/31 Javascript
C#中使用迭代器处理等待任务
2015/07/13 Javascript
AngularJS身份验证的方法
2016/02/17 Javascript
jquery仿QQ登录账号选择下拉框效果
2016/03/22 Javascript
jQuery+pjax简单示例汇总
2017/04/21 jQuery
Angular2使用Guard和Resolve进行验证和权限控制
2017/04/24 Javascript
浅析从vue源码看观察者模式
2018/01/29 Javascript
vuejs实现标签选项卡动态更改css样式的方法
2018/05/31 Javascript
bootstrap-table+treegrid实现树形表格
2019/07/26 Javascript
JavaScript变量Dom对象的所有属性
2020/04/30 Javascript
ant design vue 表格table 默认勾选几项的操作
2020/10/31 Javascript
Django中更新多个对象数据与删除对象的方法
2015/07/17 Python
python中快速进行多个字符替换的方法小结
2016/12/15 Python
Python实现爬虫从网络上下载文档的实例代码
2018/06/13 Python
Python使用__new__()方法为对象分配内存及返回对象的引用示例
2019/09/20 Python
Python实现常见的几种加密算法(MD5,SHA-1,HMAC,DES/AES,RSA和ECC)
2020/05/09 Python
Keras 使用 Lambda层详解
2020/06/10 Python
详解HTML5 LocalStorage 本地存储
2016/12/23 HTML / CSS
moosejaw旗下的户外商品促销网站:Mountain Steals
2017/02/27 全球购物
Zadig&Voltaire官网:法国时装品牌
2018/01/05 全球购物
史上最全面的Java面试题汇总!
2015/02/03 面试题
汽车制造与装配专业自荐信范文
2014/01/02 职场文书
2014年团总支工作总结
2014/11/21 职场文书
毕业生入职感言
2015/07/31 职场文书
音乐研修感悟
2015/11/18 职场文书
课文《燕子》教学反思
2016/02/17 职场文书