redux 如何使愿望列表图标保持点击后,即使重定向到其他页面?

mzaanser  于 2022-11-24  发布在  其他
关注(0)|答案(1)|浏览(116)

这是一个电子商务网站,我已经创建了一个愿望清单图标添加产品到愿望清单。愿望清单是工作得很好,当我点击图标时,产品将被添加到愿望列表页面,再次点击时,产品将从同一页面中删除。但有一个问题,当我在愿望列表中添加产品,然后刷新或转到其他页面时,图标会自动从“收藏夹”更改为“FavoriteBorderOutlined”,但该产品仍保留在购物清单中。我希望图标在再次单击之前保持不变。有人能帮我吗?

import {
  Favorite,
  SearchOutlined,
  FavoriteBorderOutlined,
} from "@material-ui/icons";
import { Link } from "react-router-dom";
import { useState, useEffect } from "react";
import styled from "styled-components";
import { popularProducts } from "../data";
import "./product.css";
import { publicRequest } from "../requestMethods";
import { useLocation } from "react-router-dom";
import { wishProduct, removeFromWishlist } from "../redux/wishlistRedux";
import { useDispatch } from "react-redux";
import {RiHeart3Fill} from 'react-icons/ri';

const Info = styled.div`
  opacity: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.2);
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.5s ease;
  cursor: pointer;
`;

const Container1 = styled.div`
  flex: 1;
  margin: 5px;
  min-width: 280px;
  height: 350px;
  display: flex;
  align-items: center;
  background-color: blue;
  background-color: #f5fbfd;
  justify-content: center;
  
  position: relative;

  &:hover ${Info}{
    opacity: 1;
  }
`;

const Container2 = styled.div`
  flex: 1;
  margin: 10px;
  width: 300px;
  height: 50px;
  display: flex;
  position: relative;
  justify-content: center;
  flex-direction: column;
`

const Circle = styled.div`
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background-color: white;
  position: absolute;
`;

const Image = styled.img`
  height: 75%;
  border-radius: 15px;
  z-index: 2;
`;

const Icon = styled.div`
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 10px;
  transition: all 0.5s ease;
  &:hover {
    background-color: #e9f5f5;
    transform: scale(1.1);
  }
`;

const SubIcon = styled.div``;

const Title = styled.div`
  height: 75%;
  font-weight: bold;
  color:black;
  align-items: left;
  width: 280px;
`;

const Span = styled.div`
  color: black;
  align-items: left;
  flex-direction: row;
  justify-content: space-between;
  padding-top: 5px;
`;

const Stock = styled.div`
  color: black;
  align-items: right;
`;

const Product = ({ item }) =>
{
  const location = useLocation();
  // const id = location.pathname.split("/")[2];
  const [quantity, setQuantity] = useState(1);
  // const [color, setColor] = useState("");
  // const [size, setSize] = useState("");
  const [product, setProduct] = useState({});
  const dispatch = useDispatch();
  const [isFilled, setIsFilled] = useState(false);
  const toggleFilledIcon = () => setIsFilled(!isFilled);

  useEffect(() => {
    const getProduct = async () => {
      try {
        const res = await publicRequest.get("/products/find/" + item.id);
        setProduct(res.data);
      } catch {}
    };
    getProduct();
  }, [item.id]);

  let inStock = "In Stock";
  let outofStock = "Out of Stock";
  let stockDetail;
  if (item.inStock) {
    stockDetail = inStock;
  }
  else {
    stockDetail = outofStock;
  }

  const handleClick = () => {
    //console.log(product, item.id)
    if(isFilled){
      dispatch(removeFromWishlist(product));
    }
    else{
      dispatch(wishProduct({ ...product, quantity }));
    }
  };
  return (
    <div>
      <Container1>
        <Circle />
        <Image src={item.img} />
        <Info>
          <Icon>
            <Link to={`/product/${item.id}`}>
              <SearchOutlined />  
            </Link>
          </Icon>
          <Icon onClick={(event)=>{
              event.preventDefault();
              event.stopPropagation();
              toggleFilledIcon();
              handleClick();
            }}>
            { isFilled ? <Favorite style={{ color: 'crimson' }} /> : <FavoriteBorderOutlined /> }
          </Icon>
        </Info>
      </Container1>
      <Container2>
        <Title>{item.title}</Title>
        <Span className="price">₹{item.price}</Span>
        <Span className="stock">{stockDetail}</Span>
      </Container2>
    </div>
  );
};

export default Product;
i7uaboj4

i7uaboj41#

我认为我们缺少一些代码来完全理解这个问题。
我的猜测如下,您的isFilled状态变量是本地的,因此当<Product/>组件卸载并重新安装时,它的状态将重置为默认值。我做了一个小的代码sandbox来尝试向您公开这一点:https://codesandbox.io/s/react-playground-forked-6f943o?file=/index.js
一个解决方案是将产品的isFilled状态变量导出到redux,这样它就可以脱离局部作用域。
请对此发表评论,以便我可以编辑此答案,如果它没有解决您的问题。

相关问题