利用localStorage设置过期时间

# 最开始是cookie存储的,后面发现后端给的token太大了,就改用localStorage了,直接上代码

function createLocalStorage() {
	/** 默认缓存期限为1天 */
	const DEFAULT_CACHE_TIME = 60 * 60 * 24 * 1;
	function set(key, value, expire = DEFAULT_CACHE_TIME) {
		const storageData = {
			value,
			expire: expire !== null ? new Date().getTime() + expire * 1000 : null,
		};
		const json = JSON.stringify(storageData);

		localStorage.setItem(key, json);
	}

	function get(key) {
		try {
			const json = localStorage.getItem(key);
			if (json) {
				let storageData = null;
				storageData = json;
				if (storageData) {
					const { value, expire } = JSON.parse(storageData);
					// 在有效期内直接返回
					if (expire === null || expire >= Date.now()) {
						return value;
					}
				}
				remove(key);
				return null;
			}
			return null;
		} catch (error) {
			return null;
		}
	}

	function remove(key) {
		localStorage.removeItem(key);
	}
	function clear() {
		localStorage.clear();
	}

	return {
		set,
		get,
		remove,
		clear,
	};
}

export const localStg = createLocalStorage();

#使用方法很简单

import { localStg } from "@/utils/storage/index";
// 清除localStorage
localStg.clear();
// 获取
localStg.get("Tokens")
//存储
localStg.set("Tokens", res.data);
// 移除
localStg.remove('tokens')

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值