feat: 全局错误捕捉

catch general js and Promise reject event to store/log, not just vue error
This commit is contained in:
李杨 2020-05-07 23:26:48 +08:00 committed by GitHub
commit 60349f0344
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 47 additions and 18 deletions

View File

@ -3,26 +3,55 @@ import util from '@/libs/util'
export default { export default {
install (Vue, options) { install (Vue, options) {
Vue.config.errorHandler = function (error, instance, info) { function writeLog (logType) {
Vue.nextTick(() => { return (error, vm, info = '') => {
// store 追加 log Vue.nextTick(() => {
store.dispatch('d2admin/log/push', { // store 追加 log
message: `${info}: ${error.message}`, store.dispatch('d2admin/log/push', {
type: 'danger', message: `${info}: ${(typeof error === 'object') ? error.message : error}`,
meta: { type: logType,
error, meta: {
instance error,
vm
}
})
// 只在开发模式下打印 log
if (process.env.NODE_ENV === 'development') {
util.log.capsule('D2Admin', 'ErrorHandler', logType)
util.log.danger('>>>>>> 错误信息 >>>>>>')
console.log(info)
util.log.danger('>>>>>> Vue 实例 >>>>>>')
console.log(vm)
util.log.danger('>>>>>> Error >>>>>>')
console.log(error)
} }
}) })
// 只在开发模式下打印 log }
if (process.env.NODE_ENV === 'development') { }
util.log.capsule('D2Admin', 'ErrorHandler', 'danger') if (process.env.NODE_ENV === 'development') {
util.log.danger('>>>>>> 错误信息 >>>>>>') Vue.config.warnHandler = writeLog('warning')
console.log(info) }
util.log.danger('>>>>>> Vue 实例 >>>>>>') Vue.config.errorHandler = writeLog('danger')
console.log(instance)
util.log.danger('>>>>>> Error >>>>>>') window.onunhandledrejection = error => {
console.log(error) store.dispatch('d2admin/log/push', {
message: (('message' in error.reason) && error.reason.message) || 'Unknown error',
type: 'danger',
meta: {
error: error.reason,
trace: 'stack' in error.reason && error.reason.stack
}
})
}
window.onerror = (event, source, lineno, colno, error) => {
store.dispatch('d2admin/log/push', {
message: (error && error.message) || 'Unknown error',
type: 'danger',
meta: {
error,
trace: error.stack,
source: `${source}@${lineno}:${colno}`,
event: event
} }
}) })
} }