JS封装本地缓存的设置,读取,移除,清空方法及使用示例

news2024/11/24 3:19:32

我封装了一个JS通用的缓存管理对象,可以提供缓存的设置,读取,移除,清空操作,使用也很方便,封装方法的代码在最下方。

Q: 为什么不直接用原生的缓存方法,要封装?

A1:原生的缓存管理起来并不方便,这里设置一个,那里设置一个,设置的缓存多了以后,没有办法统一管理,并且读取的时候还需要使用JSON.parse才能读取对象;

A2:在我封装的缓存中,加入了模块的管理,例如user模块的缓存,专门放到user模块去维护,应用全局的缓存专门放到应用中维护;

A3:加入了字典说明,注释了每个模块的作用和属性,示例:
  字典说明:
  user 用户信息模块
  -userToken 用户唯一标识
  -userName 用户昵称
  -userInfo 用户详细信息

  app 全局模块
  -source 进入应用的来源标识
  -enterTime 进入应用的时间戳

如果我想清空用户模块user中的所有属性,调用 this.$KsStorage.remove('user') 就可以,不会影响到其它的缓存数据,也支持只清空某个模块的其中一个对象或者属性,例如 user 的 userToken ,调用 this.$KsStorage.remove('user','userToken') 就可以。

下面我们看看封装的说明。

封装JS缓存
  入参字段说明:
  group          模块分组                    必填
  key             模块指定字段             非必填
  value          模块指定字段的值      非必填
  
  使用示例:
  1、设置user模块的 userInfo 对象到缓存

  this.$KsStorage.set('user','userInfo',{name:1,head:2})

2、获取user模块的所有缓存或者获取 user 模块的的 userInfo 属性
 

 this.$KsStorage.get('user') or this.$KsStorage.get('user','userInfo')

3、移除 user 模块的所有缓存或者移除 user 模块的的 userInfo 属性

  this.$KsStorage.remove('user') or this.$KsStorage.remove('user','userInfo')

4、清空所有缓存

 this.$KsStorage.clear()

封装的 ksStorage.js 完整代码:

vue,html,uniapp,react 都可以用此封装方法,统一管理应用的本地缓存



/**
  缓存管理: 所有的缓存模板分组和字段说明都在本文件添加注释
  字段说明:
  group,  模块分组,必填
  key, 模块指定字段,非必填
  value, 模块指定字段的值,非必填
  
  使用示例:
  设置user模块的userInfo到缓存
  this.$KsStorage.set('user','userInfo',{name:1,head:2})
  
  获取user模块的所有缓存或者获取user模块的的userInfo属性
  this.$KsStorage.get('user') or this.$KsStorage.get('user','userInfo')
  
  移除user模块的所有缓存或者移除user模块的的userInfo属性
  this.$KsStorage.remove('user') or this.$KsStorage.remove('user','userInfo')
  
  清空所有缓存
  this.$KsStorage.clear()
**/
let KsStorage ={
	set:(group,key,value)=>{
		let obj =JSON.parse(localStorage.getItem(group))||{};
		obj[key] = value;
		localStorage.setItem(group, JSON.stringify(obj));
	},
	get:(group,key)=>{
		let obj = JSON.parse(localStorage.getItem(group))||{};
		return key?obj[key]:obj;
	},
	remove:(group,key)=>{
		if(key){
			let obj =JSON.parse(localStorage.getItem(group))||{};
			delete obj[key];  
			localStorage.setItem(group, JSON.stringify(obj));
		}else{
			localStorage.removeItem(group);
		}
	},
	clear:()=>{
		localStorage.clear();
	},
} 
export default KsStorage;

感觉还不错的话请点个收藏加点赞吧~  谢谢~

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1394164.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL篇—性能压测工具mysqlslap介绍

☘️博主介绍☘️: ✨又是一天没白过,我是奈斯,DBA一名✨ ✌✌️擅长Oracle、MySQL、SQLserver、Linux,也在积极的扩展IT方向的其他知识面✌✌️ ❣️❣️❣️大佬们都喜欢静静的看文章,并且也会默默的点赞收藏加关注❣…

SpringBoot参数校验@Validated、@Valid

SpringBoot参数校验Validated、Valid(javax.validation) 一、应用场景 在实际开发中,前端校验并不安全,任何人都可以通过接口来调用我们的服务,就算加了一层token的校验,有心人总会转空子,来传…

如何禁用WordPress站点的管理员电子邮件验证或修改检查频率?

今天boke112百科登录某个WordPress站点时,又出现“管理员邮件确认”的提示,要求确认此站点的管理员电子邮箱地址是否仍然正确。具体如下图所示: 如果点击“稍后提醒我”,那么管理员邮件验证页面就会在3天后重新显示。 说实话&…

【JVM】JVM概述

JVM概述 基本介绍 JVM:全称 Java Virtual Machine,即 Java 虚拟机,一种规范,本身是一个虚拟计算机,直接和操作系统进行交互,与硬件不直接交互,而操作系统可以帮我们完成和硬件进行交互的工作特…

大数据开发之Hadoop(MapReduce)

第 1 章:MapReduce概述 1.1 MapReduce定义 MapReduce是一个分布式运算程序的编程框架,是用户开发“基于Hadoop的数据分析应用”的核心框架。 MapReduce核心功能是将用户编写的业务逻辑代码和自带默认组件整合成一个完整的分布式运算程序,并…

我的隐私计算学习——联邦学习(4)

本篇笔记部分内容来源于这位老师的知识分享【公众号:秃顶的码农】,我从他的资料里学到了很多,期间还私信询问了一些困惑,都得到了老师详细的答复,相当nice! (六)横向联邦学习 — 梯度…

学习VUE-安装环境

下载安装Node.js 官网下载最新版本:https://nodejs.org/en/download/ 解压zip包 由于node.js默认安装了npm所以不用额外配置全局命令就可以使用npm命令 在cmd中输入node -v 和 npm -v就可以得到版本信息 配置一下目录: node.js环境配置 配置镜像 安装…

命令行参数环境变量和进程空间地址

文章目录 命令行参数环境变量进程地址空间 正文开始前给大家推荐个网站,前些天发现了一个巨牛的 人工智能学习网站, 通俗易懂,风趣幽默,忍不住分享一下给大家。 点击跳转到网站。 命令行参数 什么是命令行参数? 我…

✅稳定检索,高校嘉宾出席,2024年机械应用与机器视觉研究国际会议(ICMAMVR 2024)

2024年机械应用与机器视觉研究国际会议(ICMAMVR 2024) 数据库:EI,CPCI,CNKI,Google Scholar 等 2024 International Conference on Mechanical Applications and Machine Vision Research(ICMAMVR 2024) 一、【会议简介】 🎉🎉 2024年机械应用…

运维平台介绍:视频智能运维平台的视频质量诊断分析和监控中心

目 录 一、概述 二、框架图 1、图像过亮检测: 2、图像模糊检测: 3、画面冻结检测: 4、信号缺失检测: 5、图像偏色检测: 6、噪声干扰检测: 7、条纹干扰检测: 三、监控中心模…

electron+vite+vue3 快速入门教程

文章目录 前言一、electron是什么?二、electron 进程模型1.主进程2.渲染进程3.预加载脚本4.进程通信4.1 sendon(单向)4.2 invokehandle (双向)4.3 主进程向渲染进程发送事件 三、窗口创建与应用事件四、技术栈和构建工具五、electron-vite安装…

母线温度预测业务需求设计

1、需求背景 需求对象:设备使用方、设备维修人员 使用场景:使用方需要对母线温度进行实时监测和预警,及时排除安全隐患,保证长期正常运行。 使用目的:准确预测母线的未来温度,对于可能存在的隐患提前预警…

【C++】STL 算法 - 累加填充算法 ( 元素累加算法 - accumulate 函数 | 元素填充算法 - fill 函数 )

文章目录 一、元素累加算法 - accumulate 函数1、函数原型分析2、代码示例 二、元素填充算法 - fill 函数1、函数原型分析2、代码示例 一、元素累加算法 - accumulate 函数 1、函数原型分析 在 C 语言 的 标准模板库 ( STL , STL Standard Template Library ) 中 , 提供了 accu…

josef约瑟 三相电压继电器 WY-35A4 100V DC220V 导轨安装

三相 WY-35A4电压继电器;WY-35B4电压继电器;WY-35C4电压继电器;WY-31A4电压继电器;WY-31B4电压继电器; WY-31C4电压继电器;JY-45A4电压继电器;JY-45B4电压继电器;JY-45C4电压继电器…

CentOS使用docker本地部署StackEdit Markdown编辑器并实现公网访问

文章目录 1. docker部署Stackedit2. 本地访问3. Linux 安装cpolar4. 配置Stackedit公网访问地址5. 公网远程访问Stackedit6. 固定Stackedit公网地址 StackEdit是一个受欢迎的Markdown编辑器,在GitHub上拥有20.7k Star!,它支持将Markdown笔记保…

再获权威认证!紫光展锐5G芯片T820荣获国密二级安全认证

近日,紫光展锐系统级安全的高性能 5G SoC T820荣获国密二级认证,这是T820获得金融科技产品认证证书后,再次荣获的行业权威认证,标志着T820在金融安全能力和应用水准位居行业前沿水平。 荣获国密二级安全认证意味着紫光展锐T820满…

力扣1929.数组串联

前言 虽然力扣对我来说很难,但只要每天刷一点,就会慢慢增强能力,总有一天刷动力扣的难题,所以说,今天也是刷力扣的一天。 😆😆 /** * Note: The returned array must be malloced, assume call…

VSCode使用Makefile Tools插件开发C/C++程序

提起Makefile,可能有人会觉得它已经过时了,毕竟现在有比它更好的工具,比如CMake,XMake,Meson等等,但是在Linux下很多C/C源码都是直接或者间接使用Makefile文件来编译项目的,可以说Makefile是基石…

vue实现导出+ 样式修改

1.安装插件 npm install xlsx-style ^0.18.5 npm install xlsx -S ^0.8.13 2. 修改代码 node_modules里面找到 以下位置xlsx.js 搜索 write_ws_xml_data 替换成以下代码 function write_ws_xml_data(ws, opts, idx, wb) {var o [], r [], range safe_decode_range(…

Kubernetes增加master节点

一. 新增节点 无论是node节点还是master节点,kubelet、kubeadm、kubectl、CRI需要部署好, ### 新增node, 重新生成token, 复制加入即可, 前提是需要装上面的 kubectl kubeadm kubelet containerd 等 kubeadm token create --print-join-command### 新增 …