Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
273 views
in Technique[技术] by (71.8m points)

javascript - Setting localStorage with cart Products

I am implementing a e-commerce project in which i want store cartItems in local storage in react so it does not disappear after refresh. Cart Items are set to local storage successfully but when i refresh it again set to empty array. here is the code:

 useEffect(() => {
    localStorage.setItem("cartItems", JSON.stringify(cart.cartItems));
}, [cart.cartItems])
useEffect(() => {
  let cartProducts = JSON.parse(localStorage.getItem("cartItems"));
  if(cartProducts){
    setCart({...cart,cartItems:[...cartProducts]});
  }
}, []) 


here is the state:
const [cart, setCart] = useState({
        cartItems: []
    });
question from:https://stackoverflow.com/questions/65843121/setting-localstorage-with-cart-products

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

On Each refresh of page, due to this stateAssignment

const [cart, setCart] = useState({cartItems: []}); This useEffect is executed.

useEffect(() => {
    localStorage.setItem("cartItems", JSON.stringify(cart.cartItems));
}, [cart.cartItems])

And at that time cart.cartItems is []. Hence it is set to [].

You need to make sure that this useEffect should only run when there is a user-initiated change in cart.cartItems.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...