【发布时间】:2018-12-05 22:25:23
【问题描述】:
我创建了一个简单的购物篮。第一个 div 将商品添加到购物车,第二个 div 将商品从购物车中移除。
刷新浏览器后,购物车中的商品消失。您如何在会话中保存这些数据?
$(document).on("click", ".addtobasket", function () {
$("#kontener_koszyka").fadeIn();
var nazwa = $(this).closest('.produkt').find('.nazwa').text();
var cena = $(this).closest('.produkt').find('.cenaprzedmiotu').text();
var suma = 0;
var li = "<li class='produkt_w_koszyku'><b>" + nazwa + "</b> <span class='cena_w_koszyku'>" + cena + " zł</span><span style='float: right; margin-right: 30px;' class='deleteitembasket'><i class=\"fas fa-times\"></i></span></li>";
$("#koszyk").append(li);
$("#koszyk .cena_w_koszyku").each(function () {
suma += parseFloat($(this).text());
});
$("#cena span").text(suma.toFixed(2));
});
$(document).on('click', '.deleteitembasket', function () {
var nazwa = $(this).closest('.produkt').find('.nazwa').text();
var cena = $(this).closest('.produkt').find('.cenaprzedmiotu').text();
var suma = 0;
var li = "<li class='produkt_w_koszyku'><b>" + nazwa + "</b> <span class='cena_w_koszyku'>" + cena + " zł</span><span style='float: right; margin-right: 30px;' class='deleteitembasket'><i class=\"fas fa-times\"></i></span></li>";
$(this).closest("li").remove();
$("#koszyk .cena_w_koszyku").each(function () {
suma += parseFloat($(this).text());
});
$("#cena span").text(suma.toFixed(2));
});
编辑: 此代码将数据存储在会话中,但是当我尝试删除单个元素 li 时,它会删除整个列表。
$(document).on("click", ".addtobasket", function () {
$("#kontener_koszyka").fadeIn();
var nazwa = $(this).closest('.produkt').find('.nazwa').text();
var cena = $(this).closest('.produkt').find('.cenaprzedmiotu').text();
var suma = 0;
var li = "<li class='produkt_w_koszyku'><b>" + nazwa + "</b> <span class='cena_w_koszyku'>" + cena + " zł</span><span style='float: right; margin-right: 30px;' class='deleteitembasket'><i class=\"fas fa-times\"></i></span></li>";
$("#koszyk").append(li);
localStorage.setItem('itemlist', (localStorage.getItem('itemlist') || '') + li);
$("#koszyk .cena_w_koszyku").each(function () {
suma += parseFloat($(this).text());
});
$("#cena span").text(suma.toFixed(2));
localStorage.setItem('sumalist', suma.toFixed(2));
});
$(document).on('click', '.deleteitembasket', function () {
var nazwa = $(this).closest('.produkt').find('.nazwa').text();
var cena = $(this).closest('.produkt').find('.cenaprzedmiotu').text();
var suma = 0;
var li = "<li class='produkt_w_koszyku'><b>" + nazwa + "</b> <span class='cena_w_koszyku'>" + cena + " zł</span><span style='float: right; margin-right: 30px;' class='deleteitembasket'><i class=\"fas fa-times\"></i></span></li>";
$(this).closest("li").remove();
/* this line remove all items in localStorage. */ localStorage.removeItem('itemlist', (localStorage.getItem('itemlist') || '') + li);
$("#koszyk .cena_w_koszyku").each(function () {
suma += parseFloat($(this).text());
});
$("#cena span").text(suma.toFixed(2));
localStorage.setItem('sumalist', suma.toFixed(2));
});
if (localStorage.getItem('itemlist') != null) {
$("#koszyk").append(localStorage.getItem('itemlist'));
$("#cena span").text(localStorage.getItem('sumalist'));
}
【问题讨论】:
-
你试过使用localStorage吗?
-
是的,但是当我只需要删除(这个)项目时,它会从 li 列表中删除所有元素。
-
如果你想在刷新浏览器之前保存数据,你需要使用 localStorage。显示您使用 localStorage 所做的一些代码,以便我们提供帮助
-
我编辑了我的帖子。
标签: javascript jquery