在“我的京东”页面中使用监听 storage 中没有结果
问题
本意是想要写一个自用的订单评价脚本,想要监听 Storage,结果发现压根没有任何返回的内容。
怀疑是京东重写了 Storage 的监听事件,监听 Message 是没问题的。
监听 Storage 没有结果的这个问题有什么办法解决吗?
能否自己重写监听事件,或者写一个不一样的监听事件?
PS: 本人已知监听的页面中进行 localStorage 的修改是不会有效果!
相关环境说明
执行脚本的地址:https://club.jd.com/myJdcomme...
修改 localStorage 是从订单页面进行,测试可以从下面两个地址中进行测试。
0 监听,1 修改
https://club.jd.com/myJdcomme...
https://club.jd.com/myJdcomme...
案例相关代码
if(/myJdcomment.action/i.test(path)){
var $btn=$('.btn-def'); //评价按钮
//注册监听 Storage 事件
console.log('注册监听 Storage 事件');
window.addEventListener('storage', function(e){
console.log('this: ', e);
});
localStorage['myJDorderVocher']=0;
}
if(/orderVoucher.action/i.test(path)) {
localStorage.setItem('myJDorderVocher','1');
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
本来就没有storage事件https://html5demos.com/storag...
似乎必须在别的同源页面窗口修改localStorage才会触发storage event
我监听storage并没有问题
还有就是修改要产生变化才会触发storage event,不变的修改不会触发