vuex中state对象会数组中的值更新后getters没有监听到state数据的改变的问题state数据跟新页面不刷新问题

问题就出现在使用这样的写法直接修改/更新state对象中的值,没错state中的值是修改到了,但是vuex监测不到的,所以很简单的方法就是整个对象去替换/赋值,这样vuex就能监测到state的变化,同事getters也会跟着变化了

赋值之后不会触发getter方法刷新,修改为深拷贝之后即可触发getter刷新

简单的处理方法是,将对象或数组转换成字符串,再转换回来,赋值就解决这个问题了

downNum(state,id){
        //将对象转换一下,从新开辟内存空间保持,然后在从新赋值,完美解决
        let cartGood = JSON.parse(JSON.stringify(state.cartGoods));
        cartGood[idx].num--;
        state.cartGoods = cartGood;
    }

可以通过JSON序列化来实现 1

vuex的mutations

addCartNum(state,id){
	let idx = state.cartGoods.findIndex((item)=>item.id == id);
    let goodsArr = JSON.parse(JSON.stringify(state.cartGoods));
    goodsArr[idx].num++;
    state.cartGoods = goodsArr;
}

可以使用vue提供的$forceUpdate方法 2

vuex的actions

addCartNumSync(context,id){
	context.commit('addCartNum',id)
}

vuex的mutations

addCartNum(state,id){
    let idx = state.cartGoods.findIndex((item)=>item.id == id);
    state.cartGoods[idx].num++;
}

页面组件代码

methods:{
    ...mapActions(['addCartNumSync']),
    add(id){
        this.addCartNumSync(id);
        //调用完成vuex中的actions操作方法对数据进行改变后
        //强制重新渲染页面,触发update生命周期钩子函数
        this.$forceUpdate();
    }
}

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JackieDYH

谢谢您嘞!我会继续加油地

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值