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


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

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

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

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

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

     

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

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

    1. Vue.config.errorHandler = (err, vm, info) => {
    2. console.log(err, vm, info);
    3. }

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

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

     

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

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

    1. instance.interceptors.response.use(
    2. (res) => {
    3. return res.data;
    4. },
    5. (err) => {
    6. let res = err.response;
    7. if (res.status >= 400) {
    8. handleError(response); // 统一处理接口异常
    9. }
    10. return Promise.reject(error);
    11. }
    12. );

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

  • 相关阅读:
    数据结构与算法
    el-table合并单元格
    Spring Boot集成tensorflow实现图片检测服务
    二分查找binary search
    责任链模式 - Unity
    【无标题】
    leetcode - 1658. Minimum Operations to Reduce X to Zero
    854. 相似度为 K 的字符串 BFS
    C#变量命名规则(命名规范)
    蓝桥杯算法记录
  • 原文地址:https://blog.csdn.net/qq_38290251/article/details/121908433