我有一个 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
属性,并且您可以获得索引 0
到 length - 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/