1、前言html
最近在用angular作商城购物车的功能模块,由于angular的watch监听,数据只要发生变化就能很方便的自动渲染页面。但随即出现的问题是,以前用户操做的样式都会被重置掉。json
例如我勾选了几个商品准备结算,又修改了商品数量,这时候发起了请求,页面数据被渲染,打钩的商品全被恢复未选中。数组
想着将全部选中商品的独有Id存入数组,利用localStorage存储,每次刷新都取到存储的数组,将数组对应Id的商品再次勾上。结果出现了下面的问题:session
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的转换达到目的。ide
2、存储数组spa
json.stringify能够将对象转换为 JSON 字符串code
JSON.parse能够将 JSON 字符串转换为对象htm
那咱们存的时候先将数组转成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"
3、存储对象blog
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的方法还能用于深拷贝,有兴趣能够看看博主这篇文章。
大概记录这么多了,谢谢阅读。