• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Renderowania Koszyka po usunięciu danego produktu

VPS Starter Arubacloud
0 głosów
90 wizyt
pytanie zadane 21 lutego 2023 w JavaScript przez ferdynand Obywatel (1,250 p.)

Dobry Wieczór ,

mam zagwozdkę, chodzi o usuwanie elementów z koszyka.

Po próbie usunieciu elementu z koszyka, usuwa mi sie on  z localStorage i dokładnie o to mi chodziło, ale nie usuwa sie z koszyka, element dalej sie wyświetla w currentCartProducts.

Jak ponownie wyrenderowac to w currentCartProducts ?

 

import { changeValueOfCounter } from "./utils.js";


const getCartProducts = async () => {
    const response = await fetch('https://fakestoreapi.com/products');
    const products = await response.json();


    return products;
};

const showCartProducts = async () => {
   const cartContainer = document.querySelector('.cart_container');
   let products = [];
   
   try {
        products = await getCartProducts();
   } catch (e) {
    console.log(e)
   }

    let cartProductsID = (JSON.parse(localStorage.getItem('cartArray'))) || [];
   
    let currentCartProducts = products.filter(product => cartProductsID.some(item => item == product.id)).map((product) => {
        cartContainer.innerHTML += `
        <div class="cart_container--product">
            <div class="cart_product--image">
            <img src=${product.image}>
            </div>
            <p class="cart_product--desc">${product.title}</p>
            <div class="cart_product-price--quantinity">
            <p>${product.price}$</p>
            <select class="cart_select" data-id=${product.id}>
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
            <option value="4">4</option>
            <option value="5">5</option>
            </select>
            <i class="fa-solid fa-trash" data-delete=${product.id}></i>
            </div>
        <div>`;
    })

    const deleteProduct = (e) => {
        let deleteIconId = e.target.getAttribute("data-delete");
        let deleteCurrentProduct = cartProductsID.filter((product) => {return product !== deleteIconId});
        if (deleteCurrentProduct) {
            cartProductsID = deleteCurrentProduct; 
            localStorage.setItem('cartArray', JSON.stringify(deleteCurrentProduct));
            changeValueOfCounter()
            console.log(cartProductsID)
        }
    }
    
    const deleteBtn = document.querySelectorAll('[data-delete]').forEach((btn) => {
        btn.addEventListener('click', deleteProduct);
    });
}
document.addEventListener('DOMContentLoaded', showCartProducts);

 

1 odpowiedź

0 głosów
odpowiedź 22 lutego 2023 przez tangarr Mędrzec (154,780 p.)
Chyba najłatwiej by było wyczyścić cartContainer i ponownie wywołać showCartProducts.
Ewentualnie wygeneruj jakiś id lub atrybut dla <div class="cart_container--product"> dzięki któremu będziesz mógł go znaleźć a potem użyj removeChild.
komentarz 22 lutego 2023 przez ferdynand Obywatel (1,250 p.)
Dzieki za pomoc :)

Podobne pytania

0 głosów
2 odpowiedzi 192 wizyt
pytanie zadane 28 maja 2020 w JavaScript przez vishi7 Początkujący (430 p.)
0 głosów
0 odpowiedzi 115 wizyt
0 głosów
0 odpowiedzi 215 wizyt

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...