React Router v7 中的 `ErrorBoundary` 详解

🛡️ 什么是 ErrorBoundary?

ErrorBoundary 是 React Router v7 中的错误边界组件,它会在以下情况下自动被调用:

  1. 路由加载失败 (loader 函数抛出错误)
  2. 组件渲染错误 (React 组件抛出异常)
  3. Action 执行失败 (action 函数抛出错误)
  4. 404 错误 (路由不存在)
  5. 其他 HTTP 错误 (如 500、403 等)

🔄 ErrorBoundary 的工作流程

让我用图表展示 ErrorBoundary 在应用中的位置:

📋 ErrorBoundary 的错误处理逻辑

jsx 复制代码
export function ErrorBoundary({ error }: Route.ErrorBoundaryProps) {
  let message = "Oops!";
  let details = "An unexpected error occurred.";
  let stack: string | undefined;

  if (isRouteErrorResponse(error)) {
    message = error.status === 404 ? "404" : "Error";
    details =
      error.status === 404
        ? "The requested page could not be found."
        : error.statusText || details;
  } else if (import.meta.env.DEV && error && error instanceof Error) {
    details = error.message;
    stack = error.stack;
  }

  return (
    <main className="pt-16 p-4 container mx-auto">
      <h1>{message}</h1>
      <p>{details}</p>
      {stack && (
        <pre className="w-full p-4 overflow-x-auto">
          <code>{stack}</code>
        </pre>
      )}
    </main>
  );
}

🎯 错误类型处理

  1. 路由响应错误 (isRouteErrorResponse(error))

    • 404 错误:显示 "页面未找到"
    • 其他 HTTP 错误:显示状态文本
  2. 开发环境的 JavaScript 错误

    • 显示错误消息和堆栈跟踪
    • 仅在开发模式下显示详细信息
  3. 通用错误

    • 显示通用错误消息

📚 ErrorBoundary 总结

🎯 ErrorBoundary 的核心作用

  1. 全局错误捕获 - 捕获整个应用中的未处理错误
  2. 用户友好的错误显示 - 显示友好的错误页面而不是白屏
  3. 开发调试支持 - 在开发模式下显示详细的错误信息
  4. 应用稳定性 - 防止单个错误导致整个应用崩溃

🔄 与 Layout 的关系

jsx 复制代码
// 渲染层次:
Layout({ children: ErrorBoundary }) // 当有错误时
  └── ErrorBoundary({ error }) 
      └── 错误页面内容

// 正常情况:
Layout({ children: App }) // 正常情况
  └── App() 
      └── <Outlet /> 
          └── 正常页面组件

🛠️ 自定义 ErrorBoundary

你可以根据不同的错误类型提供不同的处理:

  • 404 错误 - 显示 "页面未找到"
  • 500 错误 - 显示 "服务器错误"
  • 网络错误 - 显示 "网络连接问题"
  • 权限错误 - 显示 "访问被拒绝"

ErrorBoundary 是 React Router v7 提供的强大错误处理机制,确保你的应用即使在出现错误时也能保持良好的用户体验。

相关推荐
知识分享小能手8 分钟前
uni-app 入门学习教程,从入门到精通,uni-app 基础知识详解 (2)
前端·javascript·windows·学习·微信小程序·小程序·uni-app
文心快码BaiduComate17 分钟前
限时集福!Comate挂件/皮肤上线,符(福)气掉落中~
前端·后端·程序员
勇敢di牛牛17 分钟前
vue3 + mars3D 三分钟画一个地球
前端·vue.js
IT_陈寒1 小时前
Python+AI实战:用LangChain构建智能问答系统的5个核心技巧
前端·人工智能·后端
袁煦丞2 小时前
MoneyPrinterTurbo一键生成短视频:cpolar内网穿透实验室第644个成功挑战
前端·程序员·远程工作
代码小学僧2 小时前
让 AI 真正帮你开发:前端 MCP 实用技巧分享
前端
晴殇i2 小时前
前端鉴权新时代:告别 localStorage,拥抱更安全的 JWT 存储方案
前端·javascript·面试
Json____2 小时前
使用node Express 框架框架开发一个前后端分离的二手交易平台项目。
java·前端·express
since �2 小时前
前端转Java,从0到1学习教程
java·前端·学习
小奋斗2 小时前
面试官:[1] == '1'和[1] == 1结果是什么?
前端·面试