这次给你们安利的是微信小程序封装storage,先说下微信官方的

       wx.getStorage({
key:"",
success: function (res) { },
fail(error){ }
})

官方的方法用起来很麻烦,和我们之前习惯用localStorage.getItem看这个就很别扭,你也一样对吧,别问我怎么知道的  你来这文章的时候你肯定就是不习惯官方的,没关系,我给你封装好了。

第一步、根目录新建utils目录,目录内新建一个utils.js的文件

第二步、复制下方代码到utils.js文件

class Utils  {
constructor() {
super()
this.storage = {
/**
* @description 读取本地存储,
* @param { string } 要读取的key
* @param {boolean} 是否是同步
* @todo 赌气本地存储,判断key只能是string且非纯空格 如果不是将报错,
*/
Get: function (key, isSync = false) {
if (typeof key != "string") {
throw new Error("key is typeof string at Utils.storage.Get");
return false;
}
if (key.Trim() == "") {
throw new Error("key is not null at Utils.storage.Get");
return false;
}
return new Promise((resolve, reject) => {
if (isSync) {
let result = wx.getStorageSync(key.Trim());
if(result != ""){
resolve(result);
}else{
reject("getStorage:fail data not found");
}
} else {
wx.getStorage({
key:key.Trim(),
success: function (res) {
let result = res.data;
resolve(result)
},
fail(error){
reject(error.errMsg);
}
})
}
})
},
/**
* @description 设置本地存储,
* @param { string } 存储的key
* @param { * } 存储的内容
* @param {boolean} 是否是同步
* @todo 设置本地存储,判断key只能是string且非纯空格 如果不是将报错,
*/
Set: function (key, data, isSync = false) {
if (typeof key != "string") {
throw new Error("key is typeof string at Utils.storage.Set");
return false;
}
if (key.Trim() == "") {
throw new Error("key is not null at Utils.storage.Set");
return false;
}
return new Promise((resolve, reject) => {
if (isSync) {
wx.setStorageSync(key.Trim(), data)
resolve({
errMsg: "storage okey",
});
} else {
wx.setStorage({
key:key.Trim(),
data,
success: function (res) {
resolve({
errMsg: "storage okey",
})
},
})
}
})
},
/**
* @description 清理本地存储,
* @param { string } 存储的key(为空将清空所有)
* @param {boolean} 是否是同步
* @todo 清理本地存储,如果key为空则清空所有,如果key不为空则清空指定的key
*/
rm: function (key = "", isSync = false) {
if (typeof key != "string") {
throw new Error("key is typeof string at Utils.storage.rm");
return false;
}
return new Promise((resolve, reject) => {
if (key == "") {
if (isSync) {
wx.clearStorage({
success() {
resolve({
errMsg: "clearStorage is okey"
})
}
})
} else {
wx.clearStorageSync();
resolve({
errMsg: "clearStorage is okey"
})
}
} else {
if (!isSync) {
wx.removeStorage({
key:key.Trim(),
success() {
resolve({
errMsg: "clearStorage is okey"
})
}
})
} else {
wx.removeStorage(key.Trim());
resolve({
errMsg: "clearStorage is okey"
})
}
}
})
}
}
}
}
/**
* @public
* @author jinzhenzong
* @description 为string新增方法,trim为string去掉两端空格
*/
String.prototype.Trim = function () {
return this.replace(/(^\s*)|(\s*$)/g, "");
}
export {
Utils
}

第三步、使用

目标页面引入

import { Utils } from "../../utils/util.js"
data里面新建一个utils的变量,如下图所示,onload对这歌变量初始化

在需要的地方这么用:

this.data.utils.storage.Get("userser").then(res => {
console.log(res); }).catch(error => {
})

需要设置请用.Set需要异步的话请在第二个参数设为true,该文件是promise风格,兼容了对key的名称判断,以及是否是异步进行了判断,

微信小程序封装storage(含错误处理)的更多相关文章

  1. 微信小程序官方文档错误整理

    大致看了一遍微信小程序文档,发现有几处微小的错误,但瑕不掩瑜.记录下,以后发现了还会继续在此添加.如果有记录不对的,请及时指出错误. 1.视图层->WXSS->尺寸单位 明显错误,应该为 ...

  2. 关于微信小程序的Request请求错误处理

    在学微信小程序的request请求的时候,一开始报“不在以下合法域名列表中,请参考文”的错误,后来又莫名其妙的报“400 Bad Request”错误,经过半天的研究,终于搞定了,把遇到的错误给大家分 ...

  3. 微信小程序: 编译.wxss文件错误解决

    博主最近又重新开始捡起微信小程序,想做点自己的东西.了解到最近小程序工具有做更新,就顺手更新了最新的版本,功能比之前强大了不少!  更新归更新,更新后控制台就一直报下面这个错误:  解决办法 有问题总 ...

  4. 微信小程序 封装请求

    在写小程序的时候,每个JS文件都一大堆的请求,看得自己都眼花缭乱,下面看一下怎么对请求方法进行封装. 1,方法封装,在util文件夹下新建文件,创建request.js文件,工具文件,用于对方法封装) ...

  5. 微信小程序封装自定义弹窗

    最近在做小程序的登录,需要同时获取用户手机号和头像昵称等信息,但是小程序又不支持单个接口同时获取两种数据,因此想到自定义一个弹窗,通过弹窗按钮触发获取手机号事件.记录一下. 具体代码如下: 业务代码中 ...

  6. 微信小程序之上传图片(含前后端代码例子)

    此代码示例,能够让你成功将图片上传至后端,后端做相应的处理,然后返回成功码. 前端小程序代码 index.wxml: <view class='content'> <view cla ...

  7. 微信小程序封装年月日时分组件

    第一步,在page下新建component文件,放你封装的小组件,和vue里的component差不多 第二步,在需要使用的组件的.json文件中添加usingComponents 第三步,在页面中引 ...

  8. 微信小程序封装http访问网络库实例代码

    之前都是使用LeanCloud为存储,现在用传统API调用时做如下封装 var HOST = 'http://localhost/lendoo/public/index.php/'; // 网站请求接 ...

  9. 微信小程序 封装接口

    1.util-util.js //封装接口 let baseURL = 'http://127.0.0.1:3000/'; //接口路径 let request = function (url, op ...

随机推荐

  1. .NET截取指定长度字符超出部分以"..."代替

    /// <summary> /// 将指定字符串按指定长度进行剪切, /// </summary> /// <param name= "Str "&g ...

  2. Code Forces 652C Foe Pairs

    C. Foe Pairs time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  3. Get,Post请求方式详解

    前几天工作中,所有表单我都采用post方法,头儿说那样不好,大型网站上一般都采用get方法,不理解. 在网上摘到一段比较有用的话 减低服务器流量压力根据 HTTP 规范,GET 用于信息获取,而且应该 ...

  4. [py][lc]python的纸牌知识点

    模块collections-collections.namedtuple表示tuple 如表示一个坐标, t = (1,2), 搞不清楚. 如果这样就对了Point(x=1, y=2) from co ...

  5. cocos代码研究(13)Widget子类EditBox学习笔记

    理论基础 一个用来输入文本的类,继承自 Widget , 以及 IMEDelegate. 代码部分 Public枚举类型 enum KeyboardReturnType键盘的返回键类型. enum I ...

  6. 爬取乌云上所有人民币和乌云符号的漏洞(python脚本)

    import httplib from HTMLParser import HTMLParser import urlparse import urllib from bs4 import Beaut ...

  7. 20155334 2016-2017-2 《Java程序设计》第七周学习总结

    20155334 2016-2017-2 <Java程序设计>第七周学习总结 教材学习内容总结 第十二章:Lambda 认识Lammbda语法 Lambda去可以重复,符合DRY原则,而且 ...

  8. 人脸识别技术大总结(1):Face Detection & Alignment

    http://blog.jobbole.com/85783/     首页 最新文章 IT 职场 前端 后端 移动端 数据库 运维 其他技术 - 导航条 - 首页 最新文章 IT 职场 前端 - Ja ...

  9. Python3.x:open()文件操作

    Python3.x:open()文件操作 open/文件操作: #open(路径+文件名,读写模式) #读写模式:r只读,r+读写,w新建(会覆盖原有文件),a追加,b二进制文件.常用模式 f=ope ...

  10. nw.js node-webkit系列(18)怎么对.js进行编译以防你的代码暴露出来

    原文链接:http://blog.csdn.net/zeping891103/article/details/50819102 参考:https://segmentfault.com/a/119000 ...