Vue3 onErrorCaptured errorHandler 异常处理

onErrorCaptured 是 Vue 3 中的一个全局或局部生命周期钩子,用于处理组件在渲染过程中抛出的错误。当组件发生错误并且没有被任何父组件的 errorCaptured 钩子捕获时,这个钩子会被触发。它允许你在全局或局部范围内处理和记录错误,以避免整个应用因为未捕获的错误而崩溃。

全局错误处理

你可以在 Vue 应用实例化时使用 createApp 方法的 config 选项来设置全局错误处理函数:

cpp 复制代码
import { createApp } from 'vue';
import App from './App.vue';

const app = createApp(App);

app.config.errorHandler = (err, instance, source) => {
  console.error('Unhandled error:', err);
  // 可以在这里添加错误报告的逻辑,如发送到服务器
};

app.mount('#app');

局部错误处理

在组件内部,你可以使用 onErrorCaptured 钩子来捕获子孙组件中的错误:

cpp 复制代码
<script setup>
import { onErrorHandler, getCurrentInstance } from 'vue';

const instance = getCurrentInstance();

onErrorHandler((err, instance, source) => {
  console.error('Component caught an error:', err);
  // 可以在这里处理错误,例如记录到日志或显示错误信息
});
</script>

在这个例子中,onErrorHandler 是 onErrorCaptured 的一个别名,它在

错误处理的顺序

当一个错误发生时,Vue 会按照以下顺序进行错误捕获:

组件的 errorCaptured 钩子(如果有的话)。

父组件的 errorCaptured 钩子,向上逐级传递。

如果到达根实例仍未被捕获,Vue 将调用全局 config.errorHandler 钩子(如果有设置的话)。

如果全局 errorHandler 也没有捕获错误,错误将被抛出到全局错误处理机制中。

通过使用 onErrorCaptured,你可以确保应用的稳定性,即使在面对未预料的错误时也能优雅地处理。这对于生产环境中的错误监控和用户体验至关重要。

相关推荐
曹牧26 分钟前
C#:记录日志
服务器·前端·c#
小飞侠在吗29 分钟前
Vue customRef
前端·javascript·vue.js
雪碧聊技术44 分钟前
登录页【电影画风视频背景】实现
vue.js·视频背景·video标签
xhxxx1 小时前
别再让 AI 自由发挥了!用 LangChain + Zod 强制它输出合法 JSON
前端·langchain·llm
指尖跳动的光1 小时前
判断页签是否为活跃状态
前端·javascript·vue.js
用泥种荷花1 小时前
【前端学习AI】大模型调用实战
前端
Lan.W1 小时前
element UI + vue2 + html实现堆叠条形图 - 横向分段器
前端·ui·html
FAQEW2 小时前
若依(RuoYi-Vue)单体架构实战手册:自定义业务模块全流程开发指南
前端·后端·架构·若依二开
神算大模型APi--天枢6462 小时前
合规与高效兼得:国产全栈架构赋能行业大模型定制,从教育到工业的轻量化落地
大数据·前端·人工智能·架构·硬件架构
千寻girling2 小时前
马上元旦节了,手写一个《前端脚手架》庆祝一下 !
前端