前端错误-null结构

让我分析一下当 datanull 时会发生什么。 Ran tool 当 datanull 时,让我逐行分析可能发生的错误:

  1. 这里:allClasses.current = data?.class_students || [];

    • 如果 datanulldata?.class_students 会返回 undefined
    • 由于使用了 || [],这里会被赋值为空数组 []
    • 这行不会出错
  2. 这里:const { active, disable } = data?.class_students?.reduce(...)

    • 如果 datanulldata?.class_studentsundefined
    • undefined?.reduce(...) 会返回 undefined
    • 这会导致解构赋值错误TypeError: Cannot destructure property 'active' of 'undefined' as it is undefined.

让我查看这个函数的完整上下文,确认我的分析: Read file: /Users/chenyao/myProjects/teacher-web/src/pages/SchoolManage/component/MistakeStudent/index.tsx Ran tool

分析结果

datanull 时,会在 第83行 发生错误:

具体错误:

javascript 复制代码
const { active, disable } = data?.class_students?.reduce(...)
  • 如果 datanulldata?.class_students 返回 undefined

  • undefined?.reduce(...) 也返回 undefined

  • 尝试从 undefined 中解构 { active, disable } 会抛出:

    javascript 复制代码
    TypeError: Cannot destructure property 'active' of 'undefined' as it is undefined.

为什么会出错:

  1. 可选链操作符 ?. 只是避免了在 null/undefined 上调用方法时的错误
  2. 但是 reduce 方法在 undefined 上调用时返回 undefined
  3. 解构赋值 const { active, disable } = undefined 会失败

修复建议:

javascript 复制代码
const { active, disable } = data?.class_students?.reduce(
  // ... reduce logic
) || { active: [], disable: [] };

或者更安全的写法:

javascript 复制代码
const classStudents = data?.class_students || [];
const { active, disable } = classStudents.reduce(
  // ... reduce logic
  { active: [], disable: [] }
);

这样即使 datanull,代码也能正常执行,activedisable 都会被初始化为空数组。

相关推荐
遇到困难睡大觉哈哈10 小时前
Harmony os 静态卡片(ArkTS + FormLink)详细介绍
前端·microsoft·harmonyos·鸿蒙
用户479492835691511 小时前
Bun 卖身 Anthropic!尤雨溪神吐槽:OpenAI 你需要工具链吗?
前端·openai·bun
p***434811 小时前
前端在移动端中的网络请求优化
前端
g***B73811 小时前
前端在移动端中的Ionic
前端
拿破轮12 小时前
使用通义灵码解决复杂正则表达式替换字符串的问题.
java·服务器·前端
whltaoin12 小时前
【 Web认证 】Cookie、Session 与 JWT Token:Web 认证机制的原理、实现与对比
前端·web·jwt·cookie·session·认证机制
Aerelin12 小时前
爬虫playwright入门讲解
前端·javascript·html·playwright
5***o50012 小时前
前端在移动端中的NativeBase
前端
灵魂学者12 小时前
Vue3.x —— 父子通信
前端·javascript·vue.js·github
1***Q78413 小时前
前端跨域解决方案
前端