微信小程序的数据本地缓存api使用案例-Storage

数据缓存api

存储内容到指定的key 

wx.setStorageSync(string key, any data)

wx.setStorage 的同步版本

wx.setStorage({
  key:"key",
  data:"value"
})

try {
  wx.setStorageSync('key', 'value')
} catch (e) { }

获取本地缓存中指定的 key 

wx.getStorageSync(string key)

wx.getStorage 的同步版本

wx.getStorage({
  key: 'key',
  success (res) {
    console.log(res.data)
  }
})

try {
  var value = wx.getStorageSync('key')
  if (value) {
    // Do something with return value
  }
} catch (e) {
  // Do something when catch error
}

 删除指定的 key

wx.removeStorageSync(string key)

wx.removeStorage 的同步版本

wx.removeStorage({
  key: 'key',
  success (res) {
    console.log(res)
  }
})

try {
  wx.removeStorageSync('key')
} catch (e) {
  // Do something when catch error
}

 清空缓存

wx.clearStorageSync()

wx.clearStorage 的同步版本

wx.clearStorage()
try {
  wx.clearStorageSync()
} catch(e) {
  // Do something when catch error
}

示例

<!--pages/02storage/02storage.wxml-->
<view wx:for="{{lists}}" wx:key="*this" wx:for-index="i">
  <view class="title" wx:if="{{i == 0}}">童话故事</view>
  <view class="title" wx:else>早间新闻</view>
  <view class="item" wx:for="{{item}}" wx:for-item="val" wx:for-index="j" wx:key="id">
    {{val.name}}--{{i}}--{{j}}
    <button type="primary" size="mini"
      bindtap="_setStorage"
      data-i="{{i}}"
      data-j="{{j}}"
      data-id="{{val.id}}"
      data-obj="{{val}}"
    >关注</button>
  </view>
</view>
<button type="warn" bindtap="_removeStory">清除故事的缓存</button>
<button type="warn" bindtap="_clearAll">清除所有的缓存</button>

/* pages/02storage/02storage.wxss */
page{
  background-color: #eee;
}
.item{
  height: 100rpx;
  line-height: 100rpx;
  background-color: #fff;
  margin-right: 10rpx 0;
}
.title{
  color: #fff;
}
.title text{
  background-color: #ccc;
  padding: 0 40rpx;
}
button{
  vertical-align: middle;
  margin: 10rpx 0;
}

 js代码

// pages/02storage/02storage.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    lists: [
      [
          {"id":"1001","type":"1","name":"格林童话"},
          {"id":"1002","type":"1","name":"儿童童话"},
          {"id":"1003","type":"1","name":"寓言童话"}
      ],
      [
          {"id":"1004","type":"2","name":"早间新闻"},
          {"id":"1005","type":"2","name":"午间新闻"},
          {"id":"1006","type":"2","name":"晚间新闻"},
          {"id":"1007","type":"2","name":"今日新闻"}
      ]
    ]
  },
  /*设置缓存 (key,value)
  同步
  wx.setStorageSync('key', data)
  异步回调
  wx.setStorage({
    data: data,
    key: 'key',
  })
  */
  _setStorage(e){
    // 可以通过下标,或 将对象传过来
    let {i,j,id,obj} = e.currentTarget.dataset;
    // console.log(i,j,obj)
    // i:0 story 故事 i:1news新闻
    // 1 先获取对应缓存数据
    //存储成数组的结构
    //做一个分类: 故事(key:story)   新闻( key:news )
    const key = i == 0 ? 'story' : 'news';
    // 如何没有缓存 赋值默认
    let datas = wx.getStorageSync(key) || [];

    // 判断缓存是否有该数据
    let a = datas.findIndex((val,idx)=>{
      console.log(val.id===id,111)
      return val.id===id
    })
    console.log(a)
    if(a == -1){
      datas.push(this.data.lists[i][j]);
      // 存储到缓存
      wx.setStorageSync(key, datas);
    }else{
      console.log('已经存在')
    }
  },
  // 删除故事的缓存
  _removeStory(){
    wx.removeStorageSync('story')
  },
  // 删除所有
  _clearAll(){
    wx.clearStorageSync();
  }
})

 

posted @ 2020-07-13 22:48  JackieDYH  阅读(13)  评论(0编辑  收藏  举报  来源