DDR爱好者之家 Design By 杰米
背景
- 你还在为处理Uncaught (in promise) ReferenceError烦恼吗?
- 你还在为捕获异常反复的写try catch吗?
- 你还在为每一个promise写catch吗?
是时候一站式统一处理异常!!!(针对vue项目)
全局异常捕获
Vue.config.errorHandler = function (err, vm, info) { // 指定组件的渲染和观察期间未捕获错误的处理函数。这个处理函数被调用时,可获取错误信息和 Vue 实例。 // handle error // `info` 是 Vue 特定的错误信息,比如错误所在的生命周期钩子 // 只在 2.2.0+ 可用 }
注意:面对异常处理,同步异常和异步异常应该区别对待分别处理。
vue核心源码剖析
通过阅读源码看一下vue是如何将Vue.config.errorHandler接口暴露给使用者。
同步异常处理方案
// 定义异常处理函数,判断用户是否自定义Vue.config.errorHandler,定义则直接调用,未定义执行vue本身异常处理。 function globalHandleError(err, vm, info) { if (Vue.config.errorHandler) { try { return config.errorHandler.call(null, err, vm, info) } catch (e) { logError(e, null, 'config.errorHandler'); } } logError(err, vm, info); } try { // vue正常执行代码被包裹在try内,有异常会调用globalHandleError } catch (e) { globalHandleError(e, vm, '对应信息'); }
异步异常处理方案
// 定义异步异常处理函数,对于自身没有捕获异常的promise统一执行catch function invokeWithErrorHandling( handler, context, args, vm, info ) { var res; try { res = args " (Promise/async)"); }); // 异步代码例如promise可以统一为其定义Promise.prototype.catch()方法。 res._handled = true; } } catch (e) { handleError(e, vm, info); } return res } // 所有的钩子函数调用异常处理函数 function callHook(vm, hook) { var handlers = vm.$options[hook]; // 为所有钩子增加异常处理 var info = hook + " hook"; if (handlers) { for (var i = 0, j = handlers.length; i < j; i++) { invokeWithErrorHandling(handlers[i], vm, null, vm, info); } } }
知识延伸
// vue接口是能处理同步异常以及部分钩子中的异步异常,对于方法中的异常无法有效处理,我们可以仿照源码增加方式中的异步异常处理,避免为每一个promise写catch Vue.mixin({ beforeCreate() { const methods = this.$options.methods || {} Object.keys(methods).forEach(key => { let fn = methods[key] this.$options.methods[key] = function (...args) { let ret = fn.apply(this, args) if (ret && typeof ret.then === 'function' && typeof ret.catch === "function") { return ret.catch(Vue.config.errorHandler) } else { // 默认错误处理 return ret } } }) } })
完整代码
下面是全局处理异常的完整代码,已经封装成一个插件
errorPlugin.js /** * 全局异常处理 * @param { * } error * @param {*} vm */ const errorHandler = (error, vm, info) => { console.error('抛出全局异常') console.error(vm) console.error(error) console.error(info) } let GlobalError = { install: (Vue, options) => { /** * 全局异常处理 * @param { * } error * @param {*} vm */ Vue.config.errorHandler = errorHandler Vue.mixin({ beforeCreate() { const methods = this.$options.methods || {} Object.keys(methods).forEach(key => { let fn = methods[key] this.$options.methods[key] = function (...args) { let ret = fn.apply(this, args) if (ret && typeof ret.then === 'function' && typeof ret.catch === "function") { return ret.catch(errorHandler) } else { // 默认错误处理 return ret } } }) } }) Vue.prototype.$throw = errorHandler } } export default GlobalError
使用
// 在入口文件中引入 import ErrorPlugin from './errorPlugin' import Vue from 'vue' Vue.use(ErrorPlugin)
写在最后
增加全局异常处理有助于
- 提高代码健壮性
- 减少崩溃
- 快速定位bug
资料参考
- github.com/vuejs/vue/b…
- cn.vuejs.org/v2/api/#err…
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年09月19日
2024年09月19日
- 漫威终极逆转3池卡推荐 免费三池卡选哪张
- 原神岩峰巡歌突破材料大全 需要哪些材料
- 归龙潮三种乐器收集位置在哪 律笼鸟支线任务攻略
- 归龙潮火锅店宝箱密码是什么 火锅店宝箱解密攻略
- 归龙潮沉浮聆长歌任务怎么做 沉浮聆长歌任务流程攻略
- Silver阿银.2012-但愿【新世纪】【WAV+CUE】
- 瑞鸣音乐《中国音乐地图之听见西藏HQCD》[WAV]
- ChetAtkins-Sails(1987)[SACD](2015RemasterISO)
- 外网热议:你是否沉迷过某游戏 以至在现实产生联想?
- 樱花妹COS《数码宝贝》天女兽:肉感身材很吸睛
- 网游玩家玩《黑神话》玩挑食了:一个月不碰网游了
- 《阿桑 受了点伤 10首抒情佳作》[WAV+CUE][380MB]
- 《滚石爱情故事3CD》[WAV/分轨][980MB]
- 张敬轩《盛乐 2020香港中乐团演唱会》[FLAC/分轨][2.8GB]
- 李丽蕊.1987-伤心天使(2006复黑版)【永恒】【WAV+CUE】