开启微信小程序启动并加载异步问题App.js和index.js实现
前端期间,我们用微信小程序开发了一个商城项目。因为这个项目,我们的需求是通过wx.login({}) API进入小程序,在系统后台进行用户登录并获取用户的基本信息。之前我一直认为微信小程序中App.js中的onLaunch方法(该方法在小程序初始化后执行)应该先于其他页面的onload方法执行。那么问题来了。每次进入小程序首页,有时先做onlaunch方法,有时先做首页的onload方法。最后会发现微信小程序中并没有执行这两个方法。顺序,因为它们都是异步执行的。当然,开发过微信小程序的开发者都知道,微信请求数据是异步执行的。例如,如果你在同一个负载中编写两个数据请求方法,它们不一定按顺序执行。这就是传说中的异步地狱。 。
解决方案:
当然,现在我知道这个执行顺序是由异步请求启动微信小程序引起的。我们可以使用 Promise 来解决异步编程问题。我的解决方案是首先在app.js中定义一个全局方法,用于登录小程序界面请求用户信息。每次访问主页时,我首先检查是否缓存了用户信息。如果不存在,则调用app.js中的全局方法来获取数据。这里就不详细介绍Promise的基本使用了,因为阮一峰已经解释得很详细了。点击查看【es6.ruanyifeng.com/#docs/promi...
实现方法:
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()
{
//需要用到用户编号换取商品信息的接口
}
})
复制代码
总结:
解决异步回调的方法当然有很多,但这里只说我认为好用的一种。如果您有任何想法,请分享。分享学习。
作者:小楼昨夜春风
链接:https://juejin.im/post/5d70ba1ae51d4561f95eeaa6
来源:掘金
版权归作者所有商业转载请联系作者授权。非商业转载请注明出处。
版权声明
本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。