今天使用localstorage存储boolean数据时,发现怎么弄页面上数据显示就是有问题。
后面才发现,在localstorage中存储的boolean数据都变成了字符串了,才导致的。
所以"true"=true及"false"==false,“true”==false显示都为false。
上线新版本后,发现极个别“老”用户在微信浏览器中无法打开我们网站的首页。在经过一番线上文件代理替
换后,终于发现了问题所在。
问题代码段:
if(localstorage.getItem("things")){
var things = localstorage.getItem("things");
use(things);
//缓存用一次就删除
localstorage.removeItem('things');
}else{
use(newData);
}
这段代码乍一看没什么问题,但是有隐患。在老版本中,localstorage中存的things内容如下:
{
name:'px',
age:'25'
}
但是到了新版本,由于需求问题,这个缓存的值改变了,变成了如下结构:
{
username:'px',
myage:'25'
}
这样就导致了在使用use函数处理things的时候报错了,导致后面的removeItem永远不执行,所以缓存的这段数据在代码中永远不被清除,use函数一直使用旧的数据进行渲染,这样就一直报错,永远无法使用新数据。
这里有两点需要改进的
* 给缓存加版本号 * 用变量读取缓存后,立刻清除缓存
优化后的代码如下:
//先判断缓存版本号
if(localstorage.getItem("version") == curVersion){
if(localstorage.getItem("things")){
var things = localstorage.getItem("things");
//立刻清除
localstorage.removeItem('things');
use(things);
}else{
use(newData);
}
}else{
localstorage.removeItem('things');
use(newData);
}免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理