js写的一个缓存方法,可以设置过期时间

后端一直用redis作为缓存,前端用浏览器自带的缓存方法,但没有过期时间,于是自己封装了个js缓存方法,实现了类似redis一样的缓存有效期。原理就是用分隔符把缓存有效期拼到value里面,取值的时候再切割,对比有效期,过期了直接删除。

//缓存,默认有效期7天
function cache(key, value, seconds) {
	var timestamp = Date.parse(new Date()) / 1000
	if (key && value === null) {
		//删除缓存
		uni.removeStorageSync(key);
	} else if (key && value) {
		//设置缓存
		if (!seconds) {
			var expire = timestamp + (3600 * 24 * 7)
		}else{
			var expire = timestamp + seconds
		}
		value = value + "|" + expire
		uni.setStorageSync(key, value);
	} else if (key) {
		//获取缓存
		var val = uni.getStorageSync(key);
		var tmp = val.split("|")
		if (!tmp[1] || timestamp >= tmp[1]) {
			uni.removeStorageSync(key)
			return false
		} else {
			return tmp[0]
		}
	} else {
		alert("key不能空")
	}
}

上面的例子是采用uniapp的接口写的,如果是h5可以把uni.getStorageSync换成localStorage.getitem和localStorage.setitem

js cache
标题

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值