gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 20:09:15 25 4
gpt4 key购买 nike

我有一个 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com