首页
   /       /   
小程序缓存封装
9月
12
小程序缓存封装
作者:大彭Sir    分类: 教学教程

代码如下

//小程序缓存封装
class storage {
  constructor(props) {
    this.props = props || {};
    this.source = wx || this.props.source;
  }
  /**
   * 获取缓存
   * @param String $key  key
   * @param String $def  若想要无缓存时,返回默认值则get('key','默认值')(支持字符串、json、数组、boolean等等)
   * @return value;
   */
  get(key, def = '') {
    const data = this.source,
      timeout = parseInt(data.getStorageSync(`${key}__separator__`) || 0);

    // 过期失效
    if (timeout) {
      if (Date.now() > timeout) {
        this.remove(key);
        return;
      }
    }
    let value = data.getStorageSync(key);
    return value ? value : def;
  }

  /**
   * 设置缓存
   * @param String $key       key
   * @param String $value     value(支持字符串、json、数组、boolean等等)
   * @param Number $timeout   过期时间(单位:分钟)不设置时间即为永久保存
   * @return value;
   */
  set(key, value, timeout = 0) {
    let data = this.source;
    let _timeout = parseInt(timeout);
    data.setStorageSync(key, value);
    if (_timeout) {
      data.setStorageSync(`${key}__separator__`, Date.now() + 1000 * 60 * _timeout);
    } else {
      data.removeStorageSync(`${key}__separator__`);
    }

    return value;
  }

  remove(key) {
    let data = this.source;
    data.removeStorageSync(key);
    data.removeStorageSync(`${key}__separator__`);
    return undefined;
  }
}
let storages = new storage()
module.exports = {
  storages
}
本文标签:标签: 小程序
责任声明:本页信息由网友自行发布或来源于网络,真实性、合法性由发布人负责,请仔细甄别!本站只为传递信息,我们不做任何双方证明,也不承担任何法律责任。文章内容若侵犯你的权益,请联系本站删除!
转载声明:本文作者大彭Sir,如需转载请保留文章出处!原文链接请自行复制!

Theme By Brief 鄂ICP备19010459号
sitemap