【问题标题】:storing data from the basket in the session (js)在会话中存储篮子中的数据(js)
【发布时间】: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


【解决方案1】:

您必须考虑到 localStorage 存储键值对。 因此,当您存储 itemlistsomalist 时,如果它们已经存储,它们的值将被覆盖。

为此,您有几个解决方案:

  • 您可以使用唯一的密钥保存每个项目
  • 您可以保存stringify 对象,并在获取时保存parse

我最喜欢的是对象一。因此,每次您必须为 localStorage 添加或删除某些内容时,您都会获取对象(字符串),对其进行解析,进行所需的修改并再次保存。

希望对您有所帮助,干杯!

【讨论】:

  • Lobo,我不知道怎么做我需要的修改。
  • 你试过我说的吗?有什么不明白的地方吗?
  • 我不明白该怎么做。
  • 你到底有什么不明白的?
  • 我试过你可以用一个唯一的键。我该怎么做?
猜你喜欢
  • 2012-08-09
  • 1970-01-01
  • 1970-01-01
  • 2021-05-31
  • 2014-12-30
  • 2014-06-29
  • 1970-01-01
  • 1970-01-01
  • 2021-10-23
相关资源
最近更新 更多