IE本地存储userdata的一个bug说明
更新时间:2010年07月01日 23:57:04 作者:
再一次项目上用到ie的userdata,考虑当用户不使用flash插件用于存储一些聊天记录
关于userdata的简单资料:请点击这里
再一次项目上用到ie的userdata,考虑当用户不使用flash插件用于存储一些聊天记录
触发bug?条件:
1、通过userdata在同一个xml文件内存储两个属性 xxx.setAttribute('a', '111'); xxx.setAttribute('b', '222'); xxx.save('xmlname');
这时userdata对应的xml文件内是这样的 <ROOTSTUB a="111" b="222" />
2、ctrl+F5 刷新页面后,通过 xxx.removeAttribute('a'); 删除已知属性 'a'; 预期结果:<ROOTSTUB b="222" />
实际结果: <ROOTSTUB />
bug?:在删除一属性时连带删除了另一个属性
猜测:userdata在操作时可能和ie自身缓存有某种程度的绑定关联,在强刷后缓存丢失导致?
解决土方法:
在删除一属性时,请先通过 xxx.load('xmlname'); var val = xxx.getAttribute('b'); 把另一个属性load出来保存在一变量中,在removeAttribute成功后, 再把b属性setAttribute('b', val); 回去。
希望对你有帮助,谢谢。
ps:用Storage多好啊,别扭
再一次项目上用到ie的userdata,考虑当用户不使用flash插件用于存储一些聊天记录
触发bug?条件:
1、通过userdata在同一个xml文件内存储两个属性 xxx.setAttribute('a', '111'); xxx.setAttribute('b', '222'); xxx.save('xmlname');
这时userdata对应的xml文件内是这样的 <ROOTSTUB a="111" b="222" />
2、ctrl+F5 刷新页面后,通过 xxx.removeAttribute('a'); 删除已知属性 'a'; 预期结果:<ROOTSTUB b="222" />
实际结果: <ROOTSTUB />
bug?:在删除一属性时连带删除了另一个属性
猜测:userdata在操作时可能和ie自身缓存有某种程度的绑定关联,在强刷后缓存丢失导致?
解决土方法:
在删除一属性时,请先通过 xxx.load('xmlname'); var val = xxx.getAttribute('b'); 把另一个属性load出来保存在一变量中,在removeAttribute成功后, 再把b属性setAttribute('b', val); 回去。
希望对你有帮助,谢谢。
ps:用Storage多好啊,别扭
相关文章
Javascript json object 与string 相互转换的简单实现
下面小编就为大家带来一篇Javascript json object 与string 相互转换的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-09-09
最新评论