feat: 简化错误捕捉插件代码

This commit is contained in:
FairyEver 2020-05-08 08:41:37 +08:00
parent 60349f0344
commit 6628f1b462
1 changed files with 15 additions and 18 deletions

View File

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