循环必须注意事项;

虚值引起循环报错,导致代码阻塞!

今天在工作中遇见一个场景:
父组件向子组件中传递数据的时候,在子组件中父组件传递过来的数据进行循环的时候;
子组件报错
TypeError: Cannot read property 'menu_pid' of null at VueComponent.getTree
后来发现报错的原因是在进行循环的时候,
getTree(list, parentId) {
      let re = new Array();
      for (let i = 0; i < list.length; i++) {
             let pid = list[i].menu_pid; 提示这里报错
            //do something
      }
      return re;
},
发现父组件传递过来的数据 list 中有一个虚值[{},{},null];
就是这个虚值 null,导致报错了;
然后就阻塞了代码;导致后面的代码无法运行;

以后如何避免这样的问题;
在父组件向子组件传递数据的时候;
不要传递虚值,因为虚值会导致出现意想不到的错误;
在向下传递值的时候;要对值进行检查;

底层在进行循环的时候,注意代码的健壮性;

去除虚值

let arr = [11, 22, 33, null, '', undefined]

let newArr = [];

for (let i = 0; i < arr.length; i++) {
    if (arr[i]) {
        newArr.push(arr[i])
    }
}
console.log(newArr);//[11, 22, 33]
posted @   南风晚来晚相识  阅读(189)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示