微信小程序之onLaunch与onload异步问题

所述问题:

   前端时间开发了一个微信小程序商城项目,由于这个项目咱们的需求是进入小程序就经过wx.login({}) 这个api进行用户登陆,获取系统后台的用户基本信息。再此以前,一直觉得微信小程序中的App.js 中onLaunch (小程序初始化完成执行该方法)方法比其余页面的的 onload 方法要先执行。那么问题就来了,我每次进入小程序首页的时候有时候会先执行onlaunch方法,有时又会先执行首页的onload的方法,最后通过肯定,在微信小程序中这两个方法并无执行前后的顺序,由于他们都是异步执行的。固然开发过微信小程序的开发者都知道微信请求数据都是异步执行的,如在同一个onload写两个请求数据的方法,它不必定会按照前后顺序去执行,这就是传说中的异步地狱了。前端

解决方法:

  固然,我既然知道这个执行顺序是因为微信小程序的异步执行请求缘由致使的。咱们能够使用Promise 来解决异步编程问题啦。个人解决方法是,首先我是在app.js 中定义了一个全局方法,用来登陆小程序请求用户信息的接口,每次进入首页的时候先判断我是否已有用户信息缓存,假如不存在那么请求app.js中的全局方法进行数据获取。在这里我就不详细介绍Promise 的基本用法了,由于阮一峰已经将的很是详细了,你们能够点击查看【http://es6.ruanyifeng.com/#docs/promise#Promise-all】。
es6

方法实现:

App.js方法实现:

App({ onLaunch: function() { console.log('App Launch') //不在这里默认请求
}, /** * 定义全局变量 */ globalData: { openid: '', //用户openid
userId: '', //用户编号
}, /** * 用户登陆请求封装(解决onlaunch和onload执行顺序问题) */ userLogin: function() { var that = this; //定义promise方法
return new Promise(function(resolve, reject) { // 调用登陆接口
wx.login({ success: function(res) { if (res.code) { console.log("用户登陆受权code为:" + res.code); //调用wx.request请求传递code凭证换取用户openid,并获取后台用户信息
wx.request({ url: 'https://www.xxxx.xxx.api', // 后台请求用户信息方法【注意,此处必须为https数字加密证书】
data: { code: res.code //code凭证
}, header: { 'content-type': 'application/json' // 默认值
}, success(res) { console.log(res.data) if (res.data.errcode == 0) { //获取用户信息成功
that.globalData.openid = res.data.openid; that.globalData.userId = res.data.UserId; //存入session缓存中
wx.setStorageSync("userId", that.globalData.userId) console.log(that.globalData.userId); console.log(that.globalData.openid); //promise机制放回成功数据
resolve(res.data); } else { reject('error'); } }, fail: function(res) { reject(res); wx.showToast({ title: '系统错误' }) }, complete: () => { } //complete接口执行后的回调函数,不管成功失败都会调用
}) } 
else
{ reject(
"error"); } } }) }) }
});

index.js实现:

const app=getApp();//初始化app.js
page({ onLoad: function (option) { var that = this; let UserId = wx.getStorageSync("userId"); console.log("进入首页的用户编号为:" + UserId); if (UserId == '') { app.userLogin().then(res => { console.log("promise回调后的数据:"); console.log(res); if (res.errcode == 0) { //把首页须要请求的数据接口都提取到一个自定义方法中
that.GetData(); } }) } else { //用户缓存存在
that.GetData(); } } , GetData() { //须要用到用户编号换取商品信息的接口
 } })

总结:

  固然解决异步回调的方法有不少种,不过我在这里只说我认为好用的一种,你们有什么想法也能够一块儿分享学习。编程

相关文章
相关标签/搜索