微信小程序API 数据缓存

时间:2024-10-03 22:34:28

每个微信小程序都可以有自己的本地缓存,可以通过()、()、()可以对本地缓存进行设置、获取和清理。同一个微信用户,同一个小程序 storage 上限为 10MB。localStorage 以用户维度隔离,同一台设备上,A 用户无法读取到 B 用户的数据。

注意: localStorage是永久存储的,但是我们不建议将关键信息全部存在localStorage,以防用户换设备的情况。

(OBJECT)


将数据存储在本地缓存中指定的key中,会覆盖掉原来该key对应的内容,这是一个异步接口。

OBJECT参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的 key
data Object/String 需要存储的内容
success Function 接口调用成功的回调函数
fail Function 接口调用失败的回调函数
complete Function 接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

  1. wx.setStorage({
  2. key:"key"
  3. data:"value"
  4. })

(KEY,DATA)


​将data存储在本地缓存中指定的key中,会覆盖掉原来该key对应的内容,这是一个同步接口。

参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的key
data Object/String 需要存储的内容

示例代码

  1. try {
  2. wx.setStorageSync("key","value")
  3. } catch (e) {
  4. }

(OBJECT)


从本地缓存中异步获取指定key对应的内容。

OBJECT参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的 key
success Function 接口调用的回调函数,res = {data: key对应的内容}
fail Function 接口调用失败的回调函数
complete Function 接口调用结束的回调函数(调用成功、失败都会执行)

success返回参数说明:

参数 类型 说明
data String key对应的内容

示例代码:

  1. wx.getStorage({
  2. key:'key',
  3. success: function(res){
  4. console.log(res.data)
  5. }
  6. })

(KEY)


​从本地缓存中同步获取指定key对应的内容。

参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的key

示例代码:

  1. try {
  2. var value = ('key')
  3. if (value) {
  4. // Do something with return value
  5. }
  6. } catch (e) {
  7. // Do something when catch error
  8. }

(OBJECT)

异步获取当前storage的相关信息

OBJECT参数说明:

参数 类型 必填 说明
success Function 接口调用的回调函数,详见返回参数说明
fail Function 接口调用失败的回调函数
complete Function 接口调用结束的回调函数(调用成功、失败都会执行)

success返回参数说明:

参数 类型 说明
keys String Array 当前storage中所有的key
currentSize Number 当前占用的空间大小, 单位kb
limitSize Number 限制的空间大小,单位kb

示例代码:

  1. wx.getStorageInfo({
  2. success: function(res) {
  3. console.log(res.keys)
  4. console.log(res.currentSize)
  5. console.log(res.limitSize)
  6. }
  7. })

同步获取当前storage的相关信息

示例代码:

  1. try {
  2. var res = wx.getStorageInfoSync()
  3. console.log(res.keys)
  4. console.log(res.currentSize)
  5. console.log(res.limitSize)
  6. } catch (e) {
  7. // Do something when catch error
  8. }

(OBJECT)

从本地缓存中异步移除指定 key 。

OBJECT参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的 key
success Function 接口调用的回调函数
fail Function 接口调用失败的回调函数
complete Function 接口调用结束的回调函数(调用成功、失败都会执行)

示例代码:

  1. wx.removeStorage({
  2. key: 'key',
  3. success: function(res) {
  4. console.log(res.data)
  5. }
  6. })

(KEY)

从本地缓存中同步移除指定 key 。

参数说明:

参数 类型 必填 说明
key String 本地缓存中的指定的 key

示例代码:

  1. try {
  2. ('key')
  3. } catch (e) {
  4. // Do something when catch error
  5. }

()


​清理本地数据缓存。

示例代码:

wx.clearStorage()

()


同步清理本地数据缓存

示例代码:

  1. try {
  2. ()
  3. } catch(e) {
  4. // Do something when catch error
  5. }

Bug & Tip

  1. tip: 本地数据存储的大小限制为 10MB