前端错误-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 都会被初始化为空数组。

相关推荐
Bdygsl1 小时前
前端开发:HTML(5)—— 表单
前端·html
望获linux1 小时前
【实时Linux实战系列】实时数据流处理框架分析
linux·运维·前端·数据库·chrome·操作系统·wpf
国家不保护废物1 小时前
TailwindCSS:原子化CSS的革命,让React开发爽到飞起!🚀
前端·css·react.js
程序视点2 小时前
如何高效率使用 Cursor ?
前端·后端·cursor
前端领航者2 小时前
重学Vue3《 v-for的key属性:性能差异与最佳实践》
前端·javascript
归于尽2 小时前
跨域问题从青铜到王者:JSONP、CORS原理详解与实战(前端必会)
前端·浏览器
Andy_GF2 小时前
纯血鸿蒙HarmonyOS Next 远程测试包分发
前端·ios·harmonyos
嗑药狂写9W行代码2 小时前
cesium修改源码支持4490坐标系
前端
小山不高2 小时前
react实现leaferjs编辑器之形状裁剪功能点
前端
20262 小时前
13.2 ssr基本原理,构建步骤
前端·vue.js