一文教你如何实现localStorage的过期机制

  

首先需要明确 localStorage 是HTML5标准中的一种客户端存储方式,可以在浏览器中存储数据并保留在客户端本地。而过期机制则是指设置一个过期时长,在达到时限之后,数据自动失效并被清空。

下面就来介绍如何实现 localStorage 的过期机制:

步骤1:封装localStorage

首先我们需要进行封装 localStorage,以方便我们在任何时候获取存储的数据。具体实现可以参考以下代码:

const ls = window.localStorage

export const setLocalStorage = (key, value) => {
  if (typeof value !== "string") {
    value = JSON.stringify(value)
  }
  ls.setItem(key, value)
}

export const getLocalStorage = (key) => {
  let value = ls.getItem(key)
  if (/^\{.*\}$/.test(value) || /^\[.*\]$/.test(value)) {
    value = JSON.parse(value)
  }
  return value
}

export const removeLocalStorage = (key) => {
  ls.removeItem(key)
}

export const clearLocalStorage = () => {
  ls.clear()
}

在这段代码中,我们使用 Export 导出了 setLocalStorage、getLocalStorage、removeLocalStorage、clearLocalStorage 方法,它们对应着 localStorage 中的 setItem、getItem、removeItem、clear 方法。

这样我们就可以方便地封装 localStorage 了,接下来我们就要实现过期机制。

步骤2:设置过期时间

要给 localStorage 设置过期时间,我们可以把过期时间作为 value 的一个属性存进去,然后在获取 value 值的时候判断是否过期。

具体实现可以参考以下代码:

const setLocalStorageWithExpire = (key, value, expireTime) => {
  const obj = {
    value: value,
    expireTime: expireTime,
  }
  ls.setItem(key, JSON.stringify(obj))
}

const getLocalStorageWithExpire = (key) => {
  const data = ls.getItem(key)
  if (!data) {
    return null
  }
  const obj = JSON.parse(data)
  if (obj.expireTime && Date.now() - obj.expireTime > 0) {
    removeLocalStorage(key)
    return null
  }
  return obj.value
}

在这段代码中,我们新增了 setLocalStorageWithExpire 和 getLocalStorageWithExpire 方法,其中 setLocalStorageWithExpire 方法在 localStorage 中存储了一个 obj 对象,其中包含 value 和 expireTime 两个属性。getLocalStorageWithExpire 方法则在获取 value 值时,首先判断是否过期并进行清除,然后返回数据。

步骤3:应用过期机制

下面以数据获取为例应用过期机制,示例代码如下:

import { getLocalStorageWithExpire, setLocalStorageWithExpire } from "./localStorage"

const fetchData = async () => {
  const cacheData = getLocalStorageWithExpire("key1")
  if (cacheData) {
    return cacheData
  } else {
    const res = await fetch("https://example.com/api/data")
    const data = await res.json()
    setLocalStorageWithExpire("key1", data, Date.now() + 60 * 1000) // 设置60秒有效期
    return data
  }
}

在这段代码中,我们首先使用 getLocalStorageWithExpire 方法获取数据,如果数据没有过期则返回缓存数据,否则重新请求并设置有效期。这样就完成了过期机制的应用。

总结

以上就是使用 localStorage 实现过期机制的完整攻略了,我们通过封装 localStorage 并设置过期时间,最后应用过期机制来让数据自动失效并清空。可以让我们在开发中更好地利用客户端本地存储。

相关文章