feat: 简化错误捕捉插件代码
This commit is contained in:
parent
60349f0344
commit
6628f1b462
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue