- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们在 localstorage
中存储了一些数据,我们正在使用 window.setInterval()
每分钟定期更新它。在这段时间里,我们不断地读写数据。
是否有可能因为我们正在使用 setInterval()
而发生并发问题,因为多个选项卡可以同时修改 localstorage
中的数据?
编辑 1:详细解释场景:
每个选项卡都根据一个键(比如 xyz
)和 setInterval()
将一些数据写入 localstorage
,存在于运行的 javascript 中, 不断检查 xyz
关键数据。如果某些数据存在于 key 中,则 setInterval
回调会将其发送到后端。运行相同脚本的每个选项卡将读取 xyz
键并在执行一些逻辑后将一些数据附加到现有值。
我怀疑可能会出现并发问题,比如一个选项卡可能正在读取 xyz
键并将数据添加到本地存储,而另一个选项卡可能同时在做同样的事情。现在两者都会尝试同时发送数据,因此我可能会在后端收到相同的数据 2 次。
最佳答案
Is it possible that concurrency issues can occur because we're using SetInterval() as multiple tabs can modify the data in local storage simultaneously?
这有两个方面:
getItem
/setItem
(及其等效访问器)是原子的吗?getItem
/setItem
调用的不同选项卡/窗口是否可以交错调用这些调用?在#1 上,令人惊讶的是,storage specification似乎没有正面解决这个问题。在“注释”中它说:
Note
This specification does not require that the above methods wait until the data has been physically written to disk. Only consistency in what different scripts accessing the same underlying list of key/value pairs see is required.
...这对我来说意味着 getItem
/setItem
将是原子的——也就是说,如果两个线程在字面上同时调用getItem
/setItem
。
关于 #2,我认为没有任何保证,不。如果每个选项卡/窗口都有自己的线程,那么理论上这些线程中的两个可以同时进入执行这些更新的代码块。有时,选项卡/窗口共享一个线程,在这种情况下你会很安全,但是......
我会避免在 localStorage
中有很多需要以协调方式更新的不同条目。相反,我会使用带有结构的单个条目。我通常为此使用 JSON。所以获取数据看起来像这样:
let data = JSON.parse(localStorage.getItem("the-data")) || {/*...default structure here...*/};
保存起来是这样的:
localStorage.setItem("the-data", JSON.stringify(data));
所以你可以做
let data = JSON.parse(localStorage.getItem("the-data")) || {/*...default structure here...*/};
// ...modify the various parts of `data`...
localStorage.setItem("the-data", JSON.stringify(data));
然后您将在线程之间进行简单的竞争(最后写入的线程获胜),但存储的数据将是一致的。
关于javascript - 带有多个选项卡的 localstorage 和 setInterval(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56805408/
我是 Angular 新手。使用 $localstorage(ngStorage) 是否有任何特定的原因而不是常规的 javascript localstorage 有什么区别。 谁能给我解释一下吗?
这个问题说明了一切。我意识到所有选项都可以在最新的浏览器中使用,但是语义上最好的选择是什么?为什么? 最佳答案 根据 W3C 标准,正确的是 window.localStorage,因为 localS
我想不出一个好的标题,所以希望可以。 我正在做的是创建一个离线 HTML5 webapp。 “出于某些原因”我不希望将某些文件放在缓存 list 中,而是希望将内容放在 localStorage 中。
我最近问了a question about LocalStorage .使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
我最近问了a question about LocalStorage .使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
我最近问过a question about LocalStorage 。使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
我在将本地存储的定价添加到其他字段时遇到问题。如果我将 beforeNoonNPSlot 的价格设置为 2,但我将 matineeNPSlot 的字段留空(它应该保留分配给的任何价格)最后)。然后在我
我需要从 localStorage 对象变量中删除对象键而不从 localStorage 中删除键 let obj = localStorage; let keys = Object.keys(loc
根据我所读到的内容,我希望以下代码能够工作。 此代码是函数的一部分,该函数应该通过用下一个更高的 localStorage 变量覆盖它来删除 localStorage 变量。一旦没有更多内容可供复制,
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: JavaScript property access: dot notation vs. brackets? 我是
编写localStorage['key'] = value或localStorage.setItem('key', value)有区别吗? 我看到了this question标记为重复,但在开发人员工
我一直在做以下事情: var store = window.localStorage; store.setItem() 但现在我看到代码是这样做的: localStorage.setItem() 两者
我在 Chrome 上遇到此错误。不知道为什么会发生。任何帮助!我正在使用 Backbone.localStorage 插件和 Backbone。我在以下行中收到错误: localStorage: B
如果我尝试以下代码: var c = new Backbone.Collection(); c.localStorage = new Backbone.LocalStorage("items");
我想使用 localStorage 存储用户输入值,然后在倒计时器中使用该值。 这是用户输入数据的 HTML: Work Time
我有一个适用于 Mac 和 Linux 用户但不适用于 Windows 用户的 Chrome 扩展程序。当我进入控制台并在 localStorage 中设置一个项目时,它工作正常,但是当用户尝试使用扩
在这里浏览所有问题/答案,但找不到解决我的问题的方法。条件('localStorage' in window)返回 true但是 localStorage 的对象本身仍然是 undefined . 设
使用下面的代码,我创建一个 localstorage 变量,如果未定义,则其键为 quote = 1。然而,当最终使用相同的引号键再次调用它时,即使使用了 Number() 函数,它也会变成 11 而
我上次检查时,以下两行返回 true: null == localStorage["foo"]; null == localStorage.getItem("foo"); 将 null 替换为 und
我正在尝试在 NextJS 静态站点上使用 localStorage,但遇到 localStorage 未定义错误。 我的错误显示组件的代码是: export default function Cat
我是一名优秀的程序员,十分优秀!