• 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

Object Storage Arubacloud
0 głosów
93 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 197 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 234 wizyt

92,550 zapytań

141,392 odpowiedzi

319,519 komentarzy

61,935 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

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy 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!

...