解决react使用redux toolkits时出现的数组对象长度始终为0的怪异问题

有个react项目在添加购物车后,立马白屏,看一下console报错properties of undefined(reading length)

那意思是说数组没有长度,然后定位Header.tsx的182行,果然是数组长度报错

回到具体代码中:发现shoppingCartItems实际是通过redux Toolkit(RTK)的useSelector获取的

然后看一下RTK中添加购物车的代码:

没发现有异常,但是通过chrome的redux调试工具来看:

shoppingCart中的数据:item的确是undefine。

但是chrome network中post请求实际提交的是成功的。

换句话说: 添加购物车后,购物车的内容就被清空了, 为什么会这样呢?

那说明添加购物车的redux操作一定有问题,然后继续反复审查代码,果然找到了线索:

添加购物车以后,购物车state的更新竟然需要依靠请求api接口的返回值!

这就是问题的关键!

顺便说一下这个react项目的背景:这个项目是某课网的卖的一个课程,但是因为它的后端api接口经常换来换去,导致前端获取不到数据,页面没法渲染,所以我决定自己来实现api接口。

一般来说像post请求,只会返回操作是否成功这样的提示码,不会返回很细节敏感的商业信息:比如购物车详情,这很不安全也不规范。

但是很明显这个react项目的原作者就是这么干的,所以我的api逻辑跟他是不同的,我的添加购物车api请求只会提示成功还是失败。 前端页面不能依靠这个请求的返回值来更新redux的state状态。 要获取新的state,比如要发起一次get查询请求。

所以解决办法如下:

  1. 注释掉添加购物车中依靠api返回值更新state的代码:state.items = action.payload

addShoppingCartItem.fulfilled.type\]: (state, action) =\> { state.loading = false; // 添加购物车时就不应该依赖api返回值来更新本地redux。 // state.items = action.payload; state.error = null;

  1. 点击添加购物车以后,再向api查询一次购物车, 以刷新redux中购物车的state状态。

此时再点击添加购物车后,购物车就有数据了,不会再是undefined,而且是最新的数据

另外需要注意的一个点是shoppingCartState中items(购物车条目)的初始值不能是null, **而应该是一个空数组对象!**否则的话,同样会报数组长度undefined错误!因为null是没有length属性的

相关推荐
夏乌_Wx10 分钟前
mybash:简易 Shell 实现的设计思路与核心模块解析
linux·服务器·前端
滕青山41 分钟前
URL编码/解码 核心JS实现
前端·javascript·vue.js
有马贵将1 小时前
【3】前端手撕-深浅拷贝
javascript
菜鸟小芯2 小时前
【GLM-5 陪练式前端新手入门】第五篇:响应式适配 —— 让个人主页 “见机行事”
前端·人工智能
无名之逆3 小时前
你可能不需要WebSocket-服务器发送事件的简单力量
java·开发语言·前端·后端·计算机·rust·编程
加农炮手Jinx3 小时前
Flutter for OpenHarmony:web_socket_channel 全平台 WebSocket 通信标准库,从原理到鸿蒙实战(3000字深度解析)
android·前端·网络·websocket·flutter·华为·harmonyos
王码码20353 小时前
Flutter for OpenHarmony:web_socket 纯 Dart 标准 WebSocket 客户端(跨平台兼容性之王) 深度解析与鸿蒙
android·前端·websocket·网络协议·flutter·华为·harmonyos
柳杉3 小时前
使用AI从零打造炫酷的智慧城市大屏(开源):React + Recharts 实战分享
前端·javascript·数据可视化
Highcharts.js3 小时前
玩转Highcharts气泡图|从散点图到气泡图:增加一个维度,数据可视化瞬间立体起来
javascript·信息可视化·散点图·highcharts·图表开发·气泡图·图表创建
A_B_C_Q4 小时前
StringBuilder 与 StringBuffer的区别
java·前端