美文网首页
Vue错误日志捕获

Vue错误日志捕获

作者: 王二麻子88 | 来源:发表于2022-06-29 10:54 被阅读0次

    在error.js中写入

    import store from './store'
    export default {
      install: (app) => {
        app.config.errorHandler = (err, vm, info) => {
          store.commit('ADD_LOGS', {
            type: 'error',
            message: err.message,
            stack: err.stack,
            info
          })
          if (process.env.NODE_ENV === 'development') {
            console.group('>>>>>> 错误信息 >>>>>>')
            console.log(info)
            console.groupEnd();
            console.group('>>>>>> Vue 实例 >>>>>>')
            console.log(vm)
            console.groupEnd();
            console.group('>>>>>> Error >>>>>>')
            console.log(err)
            console.groupEnd();
          }
        }
      }
    }
    

    在store/modules/logs.js注册日志相关东西

    // setStore, getStore是针对localStorage和sessionStorage的封装,优先取session, setStore传入type值时声明sessionStorage存储, 默认localStorage
    import { setStore, getStore } from 'utils/store'
    import dayjs from 'dayjs'
    import { sendLogs } from '@/api/user'
    const logs = {
      state: {
        logsList: getStore({ name: 'logsList' }) || [],
      },
      actions: {
        //发送错误日志
        SendLogs ({ state, commit }) {
          return new Promise((resolve, reject) => {
            sendLogs(state.logsList).then(() => {
              commit('CLEAR_LOGS');
              resolve();
            }).catch(error => {
              reject(error)
            })
          })
        },
      },
      mutations: {
        // 添加日志
        ADD_LOGS: (state, { type, message, stack, info }) => {
          state.logsList.push(Object.assign({
            url: window.location.href,
            time: dayjs().format('YYYY-MM-DD HH:mm:ss')
          }, {
            type,
            message,
            stack,
            info: info.toString()
          }))
          setStore({ name: 'logsList', content: state.logsList })
        },
        // 清空日志
        CLEAR_LOGS: (state) => {
          state.logsList = [];
          setStore({ name: 'logsList', content: state.logsList })
        }
      }
    };
    export default logs;
    

    在main.js中注册插件

    import error from './error';
    app.use(error);
    

    相关文章

      网友评论

          本文标题:Vue错误日志捕获

          本文链接:https://www.haomeiwen.com/subject/fbytbrtx.html