Задать вопрос
@Stanl89
Учусь на вебразработчика

Подсчет суммы товаров в корзине JS?

Всем привет! Я новичок в JS. Есть корзина, как подсчитать через reduce сумму товаров в корзине и вывести в верстку?

const cart = () => {
  const buttonCart = document.getElementById("cart-button");
  const modalCart = document.querySelector(".modal-cart");
  const buttonClose = document.querySelector(".close");
  const body = modalCart.querySelector(".modal-body");
  const buttonSend = modalCart.querySelector(".button-primary");
  const buttonClear = modalCart.querySelector(".clear-cart");

  const resetCart = () => {
    body.innerHTML = "";
    localStorage.removeItem("cart");
    modalCart.classList.remove("is-open");
  };

  const incrementCount = (id) => {
    const cartArray = JSON.parse(localStorage.getItem("cart"));

    cartArray.map((item) => {
      if (item.id === id) {
        item.count++;
      }

      return item;
    });

    localStorage.setItem("cart", JSON.stringify(cartArray));
    renderItems(cartArray);
  };

  const decrementCount = (id) => {
    const cartArray = JSON.parse(localStorage.getItem("cart"));

    cartArray.map((item) => {
      if (item.id === id) {
        item.count = item.count > 0 ? item.count - 1 : 0;
      }

      return item;
    });

    localStorage.setItem("cart", JSON.stringify(cartArray));
    renderItems(cartArray);
  };

  const renderItems = (data) => {
    body.innerHTML = "";

    data.forEach(({ name, price, id, count }) => {
      const cartElem = document.createElement("div");

      cartElem.classList.add("food-row");

      cartElem.innerHTML = `<span class="food-name">${name}</span>
					<strong class="food-price">${price}</strong>
					<div class="food-counter">
						<button class="counter-button btn-dec" data-index=${id}>-</button>
						<span class="counter">${count}</span>
						<button class="counter-button btn-inc" data-index=${id}>+</button>
					</div>`;

      body.append(cartElem);
    });
  };

  body.addEventListener("click", (e) => {
    e.preventDefault();

    if (e.target.classList.contains("btn-inc")) {
      incrementCount(e.target.dataset.index);
    } else if (e.target.classList.contains("btn-dec")) {
      decrementCount(e.target.dataset.index);
    } else if (e.target.classList.contains("clear-cart")) {
      resetCart(e.target.dataset.index);
    }
  });

  buttonSend.addEventListener("click", () => {
    const cartArray = localStorage.getItem("cart");

    fetch("https://jsonplaceholder.typicode.com/posts", {
      method: "POST",
      body: cartArray,
    })
      .then((response) => {
        if (response.ok) {
          resetCart();
        }
      })
      .catch((e) => {
        console.error(e);
      });
  });

  buttonClear.addEventListener("click", () => {
    resetCart();
  });

  buttonCart.addEventListener("click", () => {
    if (localStorage.getItem("cart")) {
      renderItems(JSON.parse(localStorage.getItem("cart")));
    }

    modalCart.classList.add("is-open");
  });

  buttonClose.addEventListener("click", () => {
    modalCart.classList.remove("is-open");
  });
};

export default cart;
  • Вопрос задан
  • 872 просмотра
Подписаться 1 Простой Комментировать
Пригласить эксперта
Ответы на вопрос 1
noder_ss
@noder_ss
Линуксоид-энтузиаст и SQL разработчик
К каждому товару добавьте какой то атрибут, например value, после чего создать переменную, с значением 0, когда пользователь будет нажимать на товар, возьмите значение атрибута value, и добавьте его к ранее созданой переменной и выведите её через .innerHTML , также добавьте сам товар в вкладку товаров. На каждый товар нужно ставить такие же самый функции по клику. Если что-то не понял, напиши. Помогу, чем смогу.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы