zoukankan      html  css  js  c++  java
  • 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的方法还能用于深拷贝,有兴趣可以看看博主这篇文章。

    深拷贝与浅拷贝的区别,实现深拷贝的几种方法

    大概记录这么多了,谢谢阅读。

  • 相关阅读:
    调试PHP如何让浏览器提示错误
    接口的理解
    linux中的curl
    linux后台执行命令:&和nohup
    php定界符<<<EOF讲解
    有关字符集问题
    设置disabled属性
    PHP魔术常量
    phpstorm-有关设置
    php常用函数
  • 原文地址:https://www.cnblogs.com/echolun/p/9088189.html
Copyright © 2011-2022 走看看