React useEffect 钩子监听不到数组变化分析

React 中 useEffect 钩子函数可以简单理解为 componentDidMount 和 componentUpdateMount 结合体,使用起来是相当的舒爽。因为可以通过检测内存中变量的地址的变化,来执行副作用代码。

但是需要注意的是, useEffect 监听的是变量在内存中的地址引用,如果变量引用没有发生变化,他是监听不到的,副作用代码并不会触发执行。

很常用的场景就是,我们在做购物车要通过商品的数量变化动态计算合计金额。

实现代码:

    useEffect(() => {
        let selectedTotalCoin = 0;
        checkedItemList && checkedItemList.map(item => {
            selectedTotalCoin += item['selectedQty'] * item['cartItem']['itemDiscountPrice']
        })
        setTotalCoin(selectedTotalCoin)
    }, [checkedItemList])

    const handleSelectItem = (clickedItem, isChecked, qty, isOnlyUpdateQty) => {
        clickedItem['selectedQty'] = qty
        if (isChecked) {
            if (isOnlyUpdateQty) {
                checkedItemList.map(item => {
                    if (item['cartItemId'] === clickedItem['cartItemId']) {
                        item['selectedQty'] = qty
                    }
                    return item
                })
                setCheckedItemList(checkedItemList) // 问题代码

            } else {
                setCheckedItemList([...checkedItemList, clickedItem])
            }
        } else {
            let newCheckedItemList = []
            for (let key in checkedItemList) {
                let cartItem = checkedItemList[key]
                if (cartItem['cartItemId'] !== clickedItem['cartItemId']) {
                    newCheckedItemList.push(cartItem)
                }
            }

            setCheckedItemList(newCheckedItemList)
        }
    }

这里面合计有两个逻辑,第一个是先确定金额后点击 checkbox 选中,计算出合计金额;第二个是对已经选中的商品增减数量,计算出合计金额;useEffect 钩子则是以 选中的商品checkedItemList来做监听,动态计算。

问题就出现在第二种情况, checkedItemList 的地址引用并未发生变化,map 中的直接赋值只是改变了其中一个item 的 qty,因此不会执行副作用代码,达不到动态计算的目的。

问题代码:

 setCheckedItemList(checkedItemList)  // 这其 checkedItemList 引用并未发生变化

修正后的代码:

//方法一:解构后重新生成数组
setCheckedItemList([...checkedItemList])

//方法二:构造新的变量
let newCheckedItemList = checkedItemList
setCheckedItemList(newCheckedItemList)

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
useEffect监听数组是指在React中使用useEffect钩子函数时,可以通过将一个数组作为第二个参数传递给useEffect来指定需要监测的变量。当这些变量发生变化时,useEffect中的副作用代码会被执行。 需要注意的是,useEffect监听的是变量在内存中的地址引用,而不是变量的具体值。只有当数组中的变量引用发生变化时,useEffect才会执行副作用代码。如果变量的值发生变化但引用没有变化useEffect是无法监听到的,副作用代码也不会被执行。 useEffect的作用类似于componentDidMount和componentUpdateMount的结合体,可以通过检测内存中变量的地址变化来执行副作用代码。这使得使用useEffect非常方便和灵活。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [React hooks useEffect 监听数组变化 不生效问题](https://blog.csdn.net/weixin_45935610/article/details/126346988)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [React useEffect 钩子监听不到数组变化分析](https://blog.csdn.net/u012972536/article/details/127086784)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值