Vue 项目中的错误如何处理的?

1、 组件中的处理:使用 errorCaptured 钩子

作用:可以捕获来自后代组件的错误

父组件(errorCaptured) -> 子组件 (errorCaptured) -> 当孙子组件出错时,错误会一直向上抛,也就是先触发子组件的 errorCaptured,然后触发父组件的 errorCaptured。如果 errorCaptured 中返回 false 则会阻断传播。

原理:Vue底层源码会在很多地方都做了错误处理,例如在渲染的时候出错或者数据初始化的时候出错都会触发handleError方法,传入错误信息和实例等;再判断父组件上是否有 errorCaptured 属性,有的话拿到这个钩子便执行;判断当前钩子的返回值是否为false,为false的话就终止向上传播;

如果全局的 config.errorHandler 被定义,所有的错误仍会发送它,因此这些错误仍然会向单一的分析服务的地方进行汇报。

2、全局处理:设置错误处理 errorHandler

如果在组件渲染时出现运行错误,错误将会被传递至全局 Vue.config.errorHandler 配置函数。

javascript 复制代码
Vue.config.errorHandler = (err, vm, info) => {
    console.log(err, vm, info);
}

底层原理:每次捕获到错误之后,除了调用上级组件的 errorCaptured 之外呢,还会命中 globalHandleError方法,这个就是全局错误处理方法。将错误传到全局错误处理这里。

如果子组件返回了false,这里的全局设置也会捕获不到错误。

3、接口异常处理:响应拦截

在拦截器中对状态码进行拦截;

javascript 复制代码
instance.interceptors.response.use(
    (res) => {
        return res.data;
    },
    (err) => {
        let res = err.response;
        if (res.status >= 400) {
            handleError(response); // 统一处理接口异常
        }
        return Promise.reject(error);
    }
);

收集到错误后,提交到前端监控系统中,这样我们可以分析前端代码的异常信息啦~~

相关推荐
IT_陈寒7 小时前
React的useEffect把我坑惨了,这种闭包问题谁能想到
前端·人工智能·后端
xuankuxiaoyao7 小时前
VUE.JS实践--事件对象和计算属性
javascript·vue.js·ecmascript
前端老石人7 小时前
表单与交互式元素
前端·css·html
果粒蹬i7 小时前
自用超半年的免费 OCR 工具分享:告别付费,本地搭建更安心
前端·网络·ocr
朝阳5817 小时前
M3U8 下载助手油猴脚本 - 完全使用指南
前端·javascript·windows
早點睡3907 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-sensors(设备传感器)
javascript·react native·react.js
kadog7 小时前
GraphX:基于 WebGL 区间算术的 GPU 加速隐函数绘图器
前端·javascript·数学建模·webgl
utmhikari7 小时前
【DIY小记】解决MacOS上Edge浏览器bilibili全屏卡顿的问题
前端·macos·性能优化·edge·bilibili
上单带刀不带妹7 小时前
UniApp 页面跳转完全指南:5 种路由方式详解与实战对比
前端·javascript·vue.js·uni-app·跨端开发
大阿明8 小时前
Node.js npm 安装过程中 EBUSY 错误的分析与解决方案
前端·npm·node.js