插件开发问题记录一---localStorage使用问题

因为一开始就封装了一个选择器函数,我想着把对应的值存储到locaStorage就行了,但是我没想到我

let $=name=>document.querySelectorAll(name);

我把这个选择器获取到的对象存进了一个数组arr里,假设页面上有id为app和abc的元素,我用选择器将他们获取到,然后保存到数组arr中

let arr=[$("#app"),$("#abc")];

接着又把这个数组的值给了localStorage.arr

localStorage.arr=arr

本来以为这样就可以将保存的数据进行操作,结果我打印localStorage.arr却打印出来跟我预想不一样的

console.log(localStorage.arr)

看起来好像没问题又好像有问题

实际上这个localStorage是string类型的,也就是说,这个Value实际上就是一串字符串。

我没细想,就觉得 欸,不就是string类型转array类型么,这个简单

var newArr=localStorage.arr.split(",");
console.log(typeof newArr,newArr);

结果,它打印出来一个这样的结果

这很明显就不对了吧,数组里面怎么是string类型???

想了想,卧槽,我怎么把这个给忘了,window.localStorage存的数据都是string类型的,也就是说,我不过是把一段 [object NodeList],[object NodeList] 的字符串以逗号做分割,分成了两个数组。

思考一下,既然它只能存放string类型,那要不我直接把数组的[ ]括号改成``反引号,这样的话那也是字符串了吧,然后,然后调用的时候就,,不对啊!这不还是跟上面一样的结果么。

重新思考一下,localStorage只能存字符串,那我每次只需要存需要的字符串进去,然后需要的时候取出来,用模板字符串的方式将localStorage.arr中的数据包裹住就可以了。

修改代码

将arr改成下面这样试下

let arr=["#app","#appp"];
localStorage.arr=arr;
let newArr= localStorage.arr.split(",");

甭管localStorage里面的类型,会自动转换的

是我一开始想的太乱了,其实我并不需要存那么多东西,只需要把id或者className给存进去就行的,而且,NodeList存入数组里,也不好判断啊

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值