首页 > 热点 > 微信 > 正文

详解在微信小程序的JS脚本中使用Promise来优化函数处理

2024-07-22 01:18:59
字体:
来源:转载
供稿:网友

在我们传统的Javascript开发函数编写中,我们习惯了回调函数的处理,不过随着回调函数的增多,以及异步处理的复杂性等原因,代码越来越难读,因此诞生了使用Promise来优化JS函数处理的需求,引入Promise确实能够很好的解决异步回调函数的可读性等问题,同时也使得我们调用的时候代码简洁一些,本文介绍如何在小程序的JS代码里面使用Promise来封装一些函数的做法。

1、小程序传统的回调处理

例如我们生成一个小程序,里面的app.js里面就自动带有一个getUserInfo的函数,这个是使用传统模式的回调函数。

//app.jsApp({ onLaunch: function () { //调用API从本地缓存中获取数据 var logs = wx.getStorageSync('logs') || [] logs.unshift(Date.now()) wx.setStorageSync('logs', logs) },  getUserInfo:function(cb){ var that = this if(this.globalData.userInfo){  typeof cb == "function" && cb(this.globalData.userInfo) }else{  //调用登录接口  wx.login({  success: function () {   wx.getUserInfo({   success: function (res) {    that.globalData.userInfo = res.userInfo    typeof cb == "function" && cb(that.globalData.userInfo)   }   })  }  }) } }, globalData:{ userInfo: null, openid: null }})

这种是通过 传入一个cb的回调函数进行处理,使用的时候为了安全性,还需要进一步判断其类型是否为函数:typeof cb == "function",这种处理还是相对比较易懂。

但是,如果我们一段代码中,异步操作太多,又要保证这些异步操作是有顺序的执行,那我们的代码就看起来非常糟糕,就像这样的极端情况:

asyncFunc1(function(){ //... asyncFunc2(function(){ //... asyncFunc3(function(){  //...  asyncFunc4(function(){  //...  asyncFunc5(function(){   //...  });  }); }); });});

如果我们改用Promise来处理,那么进行一层简单的包装即可。

function asyncFunc1(){ return new Promise(function (resolve, reject) { //... })}

2、Promise的使用介绍

Promise的使用相对比较简单,我们入门可以参考下相关介绍:阮一峰 promise入门,如果我们在JS函数里面引入它的话,那么需要包含对应的javascript组件

我们可以在Github上下载对应的组件JS,引入小程序项目即可:es6-promise

我们为了方便,在项目中创建一个辅助类utils.js,然后在其中引入Promise的脚本,如下所示。

const Promise = require('./Promise')

然后在APP.js里面,我们修改原来的getUserInfo函数如下 

//app.jsconst utils = require('./utils/util.js')App({ onLaunch: function() {  //调用API从本地缓存中获取数据  var logs = wx.getStorageSync('logs') || []  logs.unshift(Date.now())  wx.setStorageSync('logs', logs) }, getUserInfo() {  return new utils.Promise((resolve, reject) => {   if (this.globalData.userInfo) {    resolve(this.globalData.userInfo)   }   return utils.getUserInfo().then(res => {    resolve(this.globalData.userInfo = res.userInfo)   })  }) }, //获取系统信息 getSystemInfo() {  return new utils.Promise((resolve, reject) => {   var that = this   if (that.globalData.systemInfo) {    resolve(that.globalData.systemInfo)   } else {    wx.getSystemInfo({     success: function(res) {      resolve(that.globalData.systemInfo = res);     }    })   }  }) }, //全局对象 globalData: {  userInfo: null,  systemInfo: null }, utils})            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表