如何解决如何根据同时更新的另一个对象更新对象的属性 - zustand?
我有一个产品,我想根据数量获取该产品的总价,我正在使用 zustand 进行状态管理。
这是我用来更新状态的函数。
export const useCartProduct = create<CartProductsProp>(
devtools(
persist(
(set) => ({
incrementProductQuantity: (product: ProductProps) => {
set((prev) => {
console.log('@userQuantity-product',product.userQuantity);
let currentCart = prev.cartProducts.map((cartProduct) =>
cartProduct.id === product.id
? {
...cartProduct,userQuantity: cartProduct.userQuantity + 1,productTotalPrice: cartProduct.userQuantity * cartProduct.price,// here's the issue "the userQuantity not updated and return the prev value".
}
: cartProduct,);
return {
cartProducts: currentCart,};
});
},}),),);
问题在这里
productTotalPrice: cartProduct.userQuantity * cartProduct.price
“userQuantity
未更新并返回上一个值”。
所以我尝试的是这样的
productTotalPrice: (cartProduct.userQuantity + 1) * cartProduct.price,
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。