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 相关文章推荐
ie 处理 gif动画 的onload 事件的一个 bug
Apr 12 Javascript
js实现的网页颜色代码表全集
Jul 17 Javascript
SyntaxHighlighter代码加色使用方法
Sep 07 Javascript
基于jquery的给文章加入关键字链接
Oct 26 Javascript
jQuery学习笔记之控制页面实现代码
Feb 27 Javascript
JS数组操作(数组增加、删除、翻转、转字符串、取索引、截取(切片)slice、剪接splice、数组合并)
May 20 Javascript
JS判断键盘是否按的回车键并触发指定按钮点击操作的方法
Feb 13 Javascript
详谈angularjs中路由页面强制更新的问题
Apr 24 Javascript
jQuery实现输入框的放大和缩小功能示例
Jul 21 jQuery
详解基于Vue2.0实现的移动端弹窗(Alert, Confirm, Toast)组件
Aug 02 Javascript
详解auto-vue-file:一个自动创建vue组件的包
Apr 26 Javascript
Vue+Express实现登录状态权限验证的示例代码
May 05 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
神族 PROTOSS 概述
2020/03/14 星际争霸
ThinkPHP之A方法实例讲解
2014/06/20 PHP
php随机取mysql记录方法小结
2014/12/27 PHP
PHP Swoole异步Redis客户端实现方法示例
2019/10/24 PHP
javascript 写类方式之八
2009/07/05 Javascript
JavaScript 空位补零实现代码
2010/02/26 Javascript
js实现的日期操作类DateTime函数代码
2010/03/16 Javascript
Firefox中autocomplete="off" 设置不起作用Bug的解决方法
2011/03/25 Javascript
JavaScript 和 Java 的区别浅析
2013/07/31 Javascript
使用text方法获取Html元素文本信息示例
2014/09/01 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
如何解决easyui自定义标签 datagrid edit combobox 手动输入保存不上
2015/12/26 Javascript
JS判断是否手机或pad访问实现方法
2016/12/09 Javascript
文件上传的几个示例分享【推荐】
2016/12/16 Javascript
jQuery操作之效果详解
2017/05/19 jQuery
基于jQuery Easyui实现登陆框界面
2017/07/10 jQuery
微信小程序icon组件使用详解
2018/01/31 Javascript
vue.js或js实现中文A-Z排序的方法
2018/03/08 Javascript
Vue 处理表单input单行文本框的实例代码
2019/05/09 Javascript
构建大型 Vue.js 项目的10条建议(小结)
2019/11/14 Javascript
vue自定义正在加载动画的例子
2019/11/14 Javascript
详解JavaScript之ES5的继承
2020/07/08 Javascript
[01:06]DOTA2小知识课堂 Ep.02 吹风竟可解梦境缠绕
2019/12/05 DOTA
[52:39]完美世界DOTA2联赛PWL S3 CPG vs Forest 第一场 12.16
2020/12/17 DOTA
[04:20]DOTA2-DPC中国联赛 正赛 VG vs LBZS 选手采访 1月19日
2021/03/11 DOTA
Python中序列的修改、散列与切片详解
2017/08/27 Python
python编程进阶之异常处理用法实例分析
2020/02/21 Python
python pandas.DataFrame.loc函数使用详解
2020/03/26 Python
Python PIL库图片灰化处理
2020/04/07 Python
python 如何读、写、解析CSV文件
2021/03/03 Python
美国社交购物市场:MassGenie
2019/02/18 全球购物
对照四风自我剖析材料
2014/10/07 职场文书
2015年团队工作总结范文
2015/05/04 职场文书
2016年小学“感恩教师”主题队日活动总结
2016/04/01 职场文书
JavaScript如何优化逻辑判断代码详解
2021/06/08 Javascript
使用vuex-persistedstate本地存储vuex
2022/04/29 Vue.js