解决localstorage存储boolean类型值的小坑

 更新时间:2021年06月04日 09:42:16   作者:梧桐芊羽  
这篇文章主要介绍了解决localstorage存储boolean类型值的小坑,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

localstorage存储boolean类型值小坑

今天使用localstorage存储boolean数据时,发现怎么弄页面上数据显示就是有问题。

后面才发现,在localstorage中存储的boolean数据都变成了字符串了,才导致的。

所以"true"=true及"false"==false,“true”==false显示都为false。

localstorage使用不严谨之坑

上线新版本后,发现极个别“老”用户在微信浏览器中无法打开我们网站的首页。在经过一番线上文件代理替

换后,终于发现了问题所在。

问题代码段:

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);
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • js正则表达式简单校验方法

    js正则表达式简单校验方法

    在本篇文章里小编给大家整理了一篇关于js正则表达式简单校验方法,有需要的朋友们可以参考下。
    2021-01-01
  • Javascript实现base64的加密解密方法示例

    Javascript实现base64的加密解密方法示例

    下文是base64用javascript写出来的函数和方法。非常不错,具有参考借鉴价值,需要的的朋友参考下吧
    2017-06-06
  • 详解JavaScript创建数组的三种方式

    详解JavaScript创建数组的三种方式

    这篇文章主要介绍了JavaScript创建数组的三种方式:直接声明, 以对象方式创建数组和使用 Array.from() 方法创建,并通过代码示例讲解的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-06-06
  • Firefox中beforeunload事件的实现缺陷浅析

    Firefox中beforeunload事件的实现缺陷浅析

    beforeunload 指在页面卸载前提供的最后一次JS执行的机会
    2012-05-05
  • js处理json以及字符串的比较等常用操作

    js处理json以及字符串的比较等常用操作

    js处理json格式的插入、修改、删除,以及字符串的比较等常用操作,下面有五个示例,感兴趣的朋友可以学习下
    2013-09-09
  • 基于bootstrap实现多个下拉框同时搜索功能

    基于bootstrap实现多个下拉框同时搜索功能

    这篇文章主要为大家详细介绍了基于bootstrap实现多个下拉框同时搜索功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • JavaScript脚本库编写的方法

    JavaScript脚本库编写的方法

    本文给大家分享javascript脚本库编写的方法,涉及到javascript脚本相关知识,对javascript脚本相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • Javascript刷新窗口方法小结

    Javascript刷新窗口方法小结

    这篇文章主要介绍了Javascript刷新窗口方法,以实例形式分析了JavaScript刷新窗口的四种常用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • JavaScript实现表格快速变色效果代码

    JavaScript实现表格快速变色效果代码

    这篇文章主要介绍了JavaScript实现表格快速变色效果的方法,通过javascript数组遍历结合时间函数来实现表格快速变色的功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • Javascript中字符串replace方法的第二个参数探究

    Javascript中字符串replace方法的第二个参数探究

    当我们要把一段字符串中的某些指定字符替换掉,第一时间想到的就是replace方法,他的用法很简单,W3school上讲的清晰易懂。网上有关replace的文章也有很多了,那么这篇这里主要聊聊它的第二个参数,下面来一起看看,注意阅读本文需要对replace方法有一定了解。
    2016-12-12

最新评论