IE本地存儲userdata的一個bug說明
更新時間:2010年07月01日 23:57:04 作者:
再一次項目上用到ie的userdata,考慮當用戶不使用flash插件用于存儲一些聊天記錄
關于userdata的簡單資料:請點擊這里
再一次項目上用到ie的userdata,考慮當用戶不使用flash插件用于存儲一些聊天記錄
觸發(fā)bug?條件:
1、通過userdata在同一個xml文件內(nèi)存儲兩個屬性 xxx.setAttribute('a', '111'); xxx.setAttribute('b', '222'); xxx.save('xmlname');
這時userdata對應的xml文件內(nèi)是這樣的 <ROOTSTUB a="111" b="222" />
2、ctrl+F5 刷新頁面后,通過 xxx.removeAttribute('a'); 刪除已知屬性 'a'; 預期結(jié)果:<ROOTSTUB b="222" />
實際結(jié)果: <ROOTSTUB />
bug?:在刪除一屬性時連帶刪除了另一個屬性
猜測:userdata在操作時可能和ie自身緩存有某種程度的綁定關聯(lián),在強刷后緩存丟失導致?
解決土方法:
在刪除一屬性時,請先通過 xxx.load('xmlname'); var val = xxx.getAttribute('b'); 把另一個屬性load出來保存在一變量中,在removeAttribute成功后, 再把b屬性setAttribute('b', val); 回去。
希望對你有幫助,謝謝。
ps:用Storage多好啊,別扭
再一次項目上用到ie的userdata,考慮當用戶不使用flash插件用于存儲一些聊天記錄
觸發(fā)bug?條件:
1、通過userdata在同一個xml文件內(nèi)存儲兩個屬性 xxx.setAttribute('a', '111'); xxx.setAttribute('b', '222'); xxx.save('xmlname');
這時userdata對應的xml文件內(nèi)是這樣的 <ROOTSTUB a="111" b="222" />
2、ctrl+F5 刷新頁面后,通過 xxx.removeAttribute('a'); 刪除已知屬性 'a'; 預期結(jié)果:<ROOTSTUB b="222" />
實際結(jié)果: <ROOTSTUB />
bug?:在刪除一屬性時連帶刪除了另一個屬性
猜測:userdata在操作時可能和ie自身緩存有某種程度的綁定關聯(lián),在強刷后緩存丟失導致?
解決土方法:
在刪除一屬性時,請先通過 xxx.load('xmlname'); var val = xxx.getAttribute('b'); 把另一個屬性load出來保存在一變量中,在removeAttribute成功后, 再把b屬性setAttribute('b', val); 回去。
希望對你有幫助,謝謝。
ps:用Storage多好啊,別扭
相關文章
Javascript json object 與string 相互轉(zhuǎn)換的簡單實現(xiàn)
下面小編就為大家?guī)硪黄狫avascript json object 與string 相互轉(zhuǎn)換的簡單實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09淺談javascript事件環(huán)微任務和宏任務隊列原理
這篇文章主要介紹了javascript事件環(huán) 微任務和宏任務隊列原理,幫助大家更好的理解和學習JavaScript,感興趣的朋友可以了解下2020-09-09Echarts中常用的參數(shù)總結(jié)及參數(shù)自定義示例代碼
Echarts中參數(shù)的配置功能很強大,對任何一項的配置都很細致,下面這篇文章主要給大家介紹了關于Echarts中常用的參數(shù)總結(jié)及參數(shù)自定義的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-02-02