使用 js-cookie 和 localStorage/sessionStorage 构建高效的浏览器缓存管理

一、localStoragesessionStorage 的基本概念
  • localStorage:用于长期存储数据,即使关闭浏览器或重启计算机后仍然存在。适合保存用户设置、偏好等不需要频繁更新的信息。
  • sessionStorage :与 localStorage 类似,但数据仅在当前会话期间有效,即当页面被关闭时数据会被清除。适用于临时性的会话信息,如购物车内容。

两者的主要区别在于数据的生命周期不同,因此在实际应用中可以根据需求选择合适的存储方式。

js-cookie 是一个轻量级的 JavaScript 库,提供了简洁的 API 来读取、写入和删除 Cookies。相比于原生的 document.cookie 接口,js-cookie 更加易用且功能丰富,支持自动编码/解码、路径和域设置等功能。

三、构建统一的缓存管理工具

为了简化 localStoragesessionStorage 的使用,并集成 js-cookie 对 Cookies 的操作,设计了两个模块:LocalSession。每个模块都包含了四个核心方法:set, get, remove, 和 clear。此外,为了确保键名的一致性和可维护性,定义了一个 setKey 方法来为每个键添加前缀。

1. Local 模块 - 浏览器永久缓存
typescript 复制代码
import Cookies from 'js-cookie';

/**
 * window.localStorage 浏览器永久缓存
 */
export const Local = {
	// 设置键名前缀
	setKey(key: string) {
		// @ts-ignore
		return `${__NEXT_NAME__}:${key}`;
	},
	// 设置永久缓存
	set<T>(key: string, val: T) {
		window.localStorage.setItem(Local.setKey(key), JSON.stringify(val));
	},
	// 获取永久缓存
	get(key: string) {
		let json = <string>window.localStorage.getItem(Local.setKey(key));
		return json ? JSON.parse(json) : null;
	},
	// 移除永久缓存
	remove(key: string) {
		window.localStorage.removeItem(Local.setKey(key));
	},
	// 移除全部永久缓存
	clear() {
		window.localStorage.clear();
	},
};
2. Session 模块 - 浏览器临时缓存
typescript 复制代码
/**
 * window.sessionStorage 浏览器临时缓存
 */
export const Session = {
	// 设置临时缓存
	set<T>(key: string, val: T) {
		if (key === 'token') return Cookies.set(key, val as string);
		window.sessionStorage.setItem(Local.setKey(key), JSON.stringify(val));
	},
	// 获取临时缓存
	get(key: string) {
		if (key === 'token') return Cookies.get(key);
		let json = <string>window.sessionStorage.getItem(Local.setKey(key));
		return json ? JSON.parse(json) : null;
	},
	// 移除临时缓存
	remove(key: string) {
		if (key === 'token') return Cookies.remove(key);
		window.sessionStorage.removeItem(Local.setKey(key));
	},
	// 移除全部临时缓存
	clear() {
		Cookies.remove('token');
		window.sessionStorage.clear();
	},
};
四、特殊处理 - token 的管理

Session 模块中,特别处理了 token 的存储和获取。由于 token 通常需要跨多个页面共享,并且可能涉及到安全性问题(如HTTPS),所以选择将其存储在 Cookies 中,而不是 sessionStoragelocalStorage。这样不仅可以保证 token 在不同页面之间的传递,还能利用 js-cookie 提供的安全特性,如设置 HttpOnlySecure 标志。

相关推荐
LawrenceLan37 分钟前
Flutter 零基础入门(十一):空安全(Null Safety)基础
开发语言·flutter·dart
txinyu的博客1 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
码不停蹄Zzz1 小时前
C语言第1章
c语言·开发语言
行者962 小时前
Flutter跨平台开发在OpenHarmony上的评分组件实现与优化
开发语言·flutter·harmonyos·鸿蒙
阿蒙Amon2 小时前
C#每日面试题-Array和ArrayList的区别
java·开发语言·c#
SmartRadio2 小时前
ESP32添加修改蓝牙名称和获取蓝牙连接状态的AT命令-完整UART BLE服务功能后的完整`main.c`代码
c语言·开发语言·c++·esp32·ble
且去填词2 小时前
Go 语言的“反叛”——为什么少即是多?
开发语言·后端·面试·go
知乎的哥廷根数学学派3 小时前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
yeziyfx3 小时前
kotlin中 ?:的用法
android·开发语言·kotlin
charlie1145141914 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式