javascript - 在不插入另一个对象的情况下更新 useState

标签 javascript reactjs react-hooks local-storage use-state

这是组件的完整代码,我累得想不出怎么解决这个问题

import React, { useEffect, useState } from 'react';
import { Link } from 'react-router-dom';


function CnContent(props) {
    const getCart = JSON.parse(localStorage.getItem('cart'));
    const products = [
        {
            id: 0,
            imgsrc: process.env.PUBLIC_URL + '/assets/images/products/grocery-staples/pro_1.jpg',
            name: "O'range 500 ml Coconut Oil(Bottle)",
            quantity: "500 ml",
            offer_price: "₹ 116",
            real_price: "₹ 219",
            inCart: 1
        },

        {
            id: 1,
            imgsrc: process.env.PUBLIC_URL + '/assets/images/products/grocery-staples/pro_2.jpg',
            name: "Parachute 100% Pure Coconut Oil (Plastic Bottle)",
            quantity: "600 ml",
            offer_price: "₹ 210",
            real_price: "₹ 250",
            inCart: 1
        },

        {
            id: 2,
            imgsrc: process.env.PUBLIC_URL + '/assets/images/products/grocery-staples/pro_3.jpg',
            name: "Fortune Soya Chunks",
            quantity: "1 kg",
            offer_price: "₹ 126",
            real_price: "₹ 135",
            inCart: 1
        },
    ]
    const [cart, setCart] = useState(getCart);

    useEffect(() => {
        localStorage.setItem('cart', JSON.stringify(cart));
    }, [cart])
    function addToCart(pr) {
        let duplicate = cart.find((x) => x.id === pr.id)

        if (!duplicate) {
            setCart((prevState) => {
                return [...prevState, pr]
            });
        }
        else {
            setCart((prevState) => [...prevState, prevState[pr.id] = { inCart: prevState[pr.id].inCart + 1 }]); // This creates another object and sends to the array (cart), but I want to change the value of the specific product(cart[pr.id]).
        }
    }

    return (
        <>
            <div className='cn-table'>
                <div className='section-left'></div>
                <div className='section-right'>

                    {
                        products.map((pr, i) => {
                            return (
                                <div tabIndex='-1' className='products' key={i}>
                                    <div className="products__wrapper">
                                        <Link to='https://www.youtube.com' className='products__link'>
                                            <div className='products__img'>
                                                <img src={pr.imgsrc} alt={pr.name}></img>
                                            </div>
                                            <div className='products__name'>{pr.name}</div>
                                            <div className='products__quantity'>{pr.quantity}</div>
                                        </Link>
                                        <div className='products__details'>
                                            <div className='products__details__price'>
                                                <div className='products__details__price__offer'>{pr.offer_price}</div>
                                                <div className='products__details__price__real'>{pr.real_price}</div>
                                            </div>
                                            <div className='add-to-cart zero-products'>
                                                <button className='add-to-cart__remove' >-</button>
                                                <button className='add-to-cart__text active'>{pr.inCart}</button>
                                                <button className='add-to-cart__add' onClick={() => addToCart(pr)}>+</button>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            )
                        })
                    }
                </div>
            </div>
        </>
    )
}

export { CnContent };

这些是 localStorage 值的结果,问题不是更改特定对象的 inCart 的值,而是创建一个具有属性“inCart”的新对象。

0: {id: 0, pr_category: "grocery-staples", imgsrc: "/assets/images/products/grocery-staples/pro_1.jpg",…}
1: {id: 1, pr_category: "grocery-staples", imgsrc: "/assets/images/products/grocery-staples/pro_2.jpg",…}
2: {inCart: 1} /*Instead of this new object I want to change the value in the upper objects*/

任何建议将不胜感激。谢谢!

编辑:将 inCart 的值从 0 更改为 1。

最佳答案

您需要映射购物车并仅更新您想要的产品

setCart((prevState) => prevState.map(product=>{
   if (product.id === pr.id) {
    return {
      ...product,
      inCart: product.inCart + 1
    }
   }
   return product;
});

关于javascript - 在不插入另一个对象的情况下更新 useState,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65834809/

相关文章:

javascript - Vuejs 和 VueRouter SEO

javascript - 使用 jQuery,如何将信息存储在动态创建的 div 中?

reactjs - SequelizeDatabaseError 数据在第 4 行的列位置被截断

javascript - React useEffect Hook 中对象和数组依赖项的 ESLint 规则

reactjs - 为什么 destroyOnClose={true} 在 React 中不起作用

javascript - 你能在 Angular 2 中有一个独立的指令吗

javascript - 无法将 .onClick 方法添加到子组件中的对象

javascript - 重新渲染一个子组件(React with Hooks)

javascript - 如何映射图像数组并将其用作 React 中的内联样式

javascript - 使用 useState 更新 React 中多个复选框的状态