失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > localStorage存储数组 对象 localStorage sessionStorage存储数组对象

localStorage存储数组 对象 localStorage sessionStorage存储数组对象

时间:2021-11-13 21:19:04

相关推荐

localStorage存储数组 对象 localStorage sessionStorage存储数组对象

localStorage存储数组,对象,localStorage,sessionStorage存储数组对象

前言

最近在用angular做商城购物车的功能模块,因为angular的watch监听,数据只要发生变化就能很方便的自动渲染页面。但随即出现的问题是,之前用户操作的样式都会被重置掉。

例如我勾选了几个商品准备结算,又修改了商品数量,这时候发起了请求,页面数据被渲染,打钩的商品全被恢复未选中。

想着将所有选中商品的独有Id存入数组,利用localStorage存储,每次刷新都取到存储的数组,将数组对应Id的商品再次勾上。结果出现了下面的问题:

var a = [1,2,3];window.localStorage.setItem('key',a);var b = window.localStorage.getItem('key');console.log(b,typeof b);//1,2,3 string

很明显,数组存进去直接被强转为了字符串类型,这明显不是我想要的,查了下,可以利用json.stringify与JSON.parse的转换达到目的。

存储数组

json.stringify可以将对象转换为 JSON 字符串

JSON.parse可以将JSON 字符串转换为对象

那我们存的时候先将数组转成JSON字符串,取出来再转成数组就可以了,实现如下。

function storageObj(obj) {var checkedIdStr = JSON.stringify(obj);sessionStorage.setItem("key", checkedIdStr);};var arrBefor = [1,2,3];storageObj(arrBefor);var arrAfter = JSON.parse(sessionStorage.getItem("key"));console.log(arrAfter,typeof arrAfter);//[1, 2, 3] "object"

存储对象

function storageObj(obj) {var checkedIdStr = JSON.stringify(obj);sessionStorage.setItem("key", checkedIdStr);};var objBefor = {a:1,b:2};storageObj(objBefor);var objAfter = JSON.parse(sessionStorage.getItem("key"));console.log(objAfter,typeof objAfter);//{a: 1, b: 2} "object"

利用JSON转换值达到存储的的方式非常好用,除此之外JSON的方法还能用于深拷贝,有兴趣可以看看博主这篇文章。

如果觉得《localStorage存储数组 对象 localStorage sessionStorage存储数组对象》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。