localstorage可以存多少(解决localstorage存储boolean类型值的小坑)
类别:编程学习 浏览量:2663
时间:2022-01-18 01:49:03 localstorage可以存多少
解决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); }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。
您可能感兴趣
- LocalStorage用法
- localstorage可以存多少(解决localstorage存储boolean类型值的小坑)
- localstorage底层技术(浅谈Web Storage API的使用)
- 详解如何获取localStorage最大存储大小的方法(详解如何获取localStorage最大存储大小的方法)
- HTMl5 sessionStorage和localStorage
- cookie和session流程(浅析数据存储的三种方式 cookie sessionstorage localstorage 的异同)
- 赵薇时胖时瘦 最近变美少女 原因在这里 躺着就变瘦(赵薇时胖时瘦最近变美)
- 学会这26种姿势,你就可以和兵哥哥切磋了(你就可以和兵哥哥切磋了)
- 吴彦祖陈冠希 恩怨 ,失去曾让他流泪的女友,终遇走过18年真爱(吴彦祖陈冠希恩怨)
- 痴情男神 吴彦祖 与妻子恋爱8年,结婚10年,家庭幸福美满(痴情男神吴彦祖)
- 成功破圈,小牛电动SQi强势开 跨(小牛电动SQi强势开)
- 挑战新国标电自天花板,九号机械师MMAX 110P深度体验(挑战新国标电自天花板)
热门推荐
- dede友情链接改为logo轮播教程(织梦dede调用四级栏目的实现方法)
- canvas技术开发(用canvas显示验证码的实现)
- python如何编写判断正负数程序(Python实现判断一个整数是否为回文数算法示例)
- uni-app搜索框源代码(如何用uni-app实现顶部导航栏显示按钮和搜索框)
- mysql三种查询方式(MySQL查询学习之基础查询操作)
- str怎么把最后一个字符去掉(因str_replace导致的注入问题总结)
- 微信小程序function怎么使用(微信小程序在{{ }}中直接使用函数的方法示例)
- mysql在centos7中如何安装(阿里云centos7安装mysql8.0.22的详细教程)
- vuex存取修改数据流程(vuex数据持久化的两种实现方案)
- docker redis安装配置(在docker中部署并启动redis的方法)