javascript - 如何阻止 Chrome 和 Firefox 按字母顺序按键对 sessionStorage 进行排序?

标签 javascript html session-storage

我有一个 JS 脚本,它向 sessionStorage 添加 (sessionStorage.setItem()) 和删除 (sessionStorage.removeItem()) 项目。它的工作原理是添加一个项目会将其附加到 sessionStorage 数组的末尾。它在 Edge 中按预期工作,但在 Chrome 和 Firefox 中测试时,在将项目添加到 sessionStorage 后,sessionStorage 会按字母顺序键重新排序,这意味着添加的最后一个项目不会位于数组的末尾,这会破坏整个脚本.我该如何防止这种情况? 这是将项目添加到 sessionStorage 的函数:

function addToCompareList(productName, productID, productHref) {
        var existsInCompare = false;
        for(var i = 0; i < sessionStorage.length; i++) {
            if(sessionStorage.key(i) == productName) {
                existsInCompare = true;
                break;
            }
        }
        if(!existsInCompare) {
            sessionStorage.setItem(productName, productID + ',' + productHref);
        }
        //item limit should be 4, so if storage exceeds limit, remove oldest item. This is the part that becomes faulty in some browsers
        if(sessionStorage.length > 4) {
            sessionStorage.removeItem(sessionStorage.key(0));
        }
    }

这是将项目添加到 sessionStorage 的函数的代码。

添加项目后,循环 session 存储和 console.log()-ing 每个项目在不同浏览器中的工作方式不同:在 Edge 中,项目按照添加的顺序记录,在 Chrome 和 Firefox 中,它们得到按字母顺序记录,这意味着代码的注释部分无法按预期工作。

最佳答案

尽管存储具有 length 属性,并且您可以获得索引 0length - 1 的键,但它不是 一个数组,它没有定义的顺序。来自 the spec :

The key(n) method must return the name of the nth key in the list. The order of keys is user-agent defined, but must be consistent within an object so long as the number of keys doesn't change. (Thus, adding or removing a key may change the order of the keys...

(我的重点)

如果您想要定义的顺序,请通过 JSON 在存储器中存储一个数组而不是存储单个条目:

在页面加载/从存储读取时,从存储中获取数组:

entries = JSON.parse(sessionStorage.getItem("entries") || "[]");

请注意,如果 "entries" 不在 sessionStorage 中,getItem 将返回 null,因此我们为 JSON.parse 提供默认的 "[]" 进行解析。 (给那只猫剥皮的方法有很多,这只是其中一种。)

当你想保存到存储空间时:

sessionStorage.setItem("entries", JSON.stringify(entries));

这样,条目就会按照定义的顺序(数组的顺序)。


重新编辑:entries 将是您产品的一组对象。

关于javascript - 如何阻止 Chrome 和 Firefox 按字母顺序按键对 sessionStorage 进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52569150/

相关文章:

html - 当点击目标 ="_blank"的链接时,新窗口上的 sessionStorage 不为空

javascript - JS,将数组数据保存在 sessionStorage 中的问题

javascript - JSON 更改时如何更新

javascript - 从 v10 升级到 v12 - AzureSDK JS

javascript - 无法使用 javascript 获取其余响应

javascript - 使用angularJS将json模板编码为html的方法是什么?

javascript - JS : how to get tbody index in table

JavaScript 计时问题 - 在设置 sessionStorage 值之前关闭窗口

javascript - 在服务器端将集合 AS 文件从文件系统转换为 gridFS

javascript - 通过方法动态改变元素数据