数据存储工具箱—Vue项目中对Storage的封装

8 篇文章 0 订阅
1 篇文章 0 订阅


Vue项目中对Storage的封装,实现数据的存储、读取、删除,通过json形式操作并读写该对象。

1.Storage的封装

// Storage封装
const STORAGE_KEY = 'mall'//设置一个独一无二的key
//导出默认对象
export default{
    // 存储值
    setItem(key,value,module_name){
        if(module_name){//如果存在模块,先取出模块
            let val = this.getItem(module_name);
            val[key] = value
            this.setItem(module_name,val)//此时大对象为module_name(模块)
        }else{
            let val = this.getStorage();//val为整个大对象
            val[key] = value;
            //val是json对象 需要将其转化成字符串 ,将重新设置的大对象值赋给STORAGE_KEY
            window.sessionStorage.setItem(STORAGE_KEY,JSON.stringify(val))
        }
    },
    // 获取值,获取某一个模块下的属性(module_name:user下面的val[key]:username)
    getItem(key,module_name){
        if(module_name){//如果存在模块
            let val = this.getItem(module_name);
            if(val) return val[key];
        }
        return this.getStorage()[key];
    },
    // 获取整个数据,获取浏览器中的环境信息,信息都在mall中
    getStorage(){
        JSON.parse(window.sessionStorage.getItem(STORAGE_KEY) || '{}');
    },
    // 清空每个值
    clear(key,module_name){
        let val = this.getStorage();
        if(module_name){//有模块,干掉该模块下的属性
            if(!val[module_name])return;
            delete val[module_name][key];
        }else{//无模块,直接干掉属性
            delete val[key];
        }
        //重新将值写入
        window.sessionStorage.setItem(STORAGE_KEY,JSON.stringify(val))
    }
}

2.Storage的使用

后期补充…

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值