今天在调试小程序的过程当中,进了一个坑,程序加载须要先获取用户信息,而后保存到Storage中,而后首页去php
Storage取信息,根据用户信息去查本地服务器数据列表,但是发现第一次进入的时候,数据老是加载不出来,只有再次进入才有数据。调试以后发现app.js onLaunch并无先于onLoad 执行完再执行,而是onLoad先执行完,因此第一次进入的时候根本没有Storage,追了下缘由是由于wx.login是须要用户受权登陆,同时异步加载首页,因此就出现这问题,解决办法小程序
一、加一个启动页,获取成功后,而后再跳转首页;api
二、使用promise,判断进程状态,在index中去判断进程状态,再去执行页面的加载。promise
解释下Promise:缓存
var promise = new Promise(function(resolve, reject) {
if (/* 异步操做成功 */){
resolve(value);
} else {
reject(error);
}
});
promise.then(function(value) {
// success
}, function(value) {
// failure
});
Promise 构造函数接受一个函数做为参数,该函数的两个参数分别是 resolve 方法和 reject 方法。服务器
若是异步操做成功,则用 resolve 方法将 Promise 对象的状态,从「未完成」变为「成功」(即从 pending 变为 resolved);app
若是异步操做失败,则用 reject 方法将 Promise 对象的状态,从「未完成」变为「失败」(即从 pending 变为 rejected)。异步
贴一下APP.js代码:函数
//app.js
var http = require('service/http.js')
App({
onLaunch: function() {
//调用API从本地缓存中获取数据
// var that = this;
},
getAuthKey: function () {
var that = this;
return new Promise(function (resolve, reject) {
// 调用登陆接口
wx.login({
success: function (res) {
if (res.code) {
that.globalData.code = res.code;
//调用登陆接口
wx.getUserInfo({
withCredentials: true,
success: function (res) {
that.globalData.UserRes = res;
that.globalData.userInfo = res.userInfo;
that.func.postReq('/api/v1/image/oauth', {
code: that.globalData.code,
signature: that.globalData.UserRes.signature,
encryptedData: that.globalData.UserRes.encryptedData,
rawData: that.globalData.UserRes.rawData,
iv: that.globalData.UserRes.iv
}, function (res) {
wx.setStorage({
key: "auth_key",
data: res.data.auth_key
})
var res = {
status: 200,
data: res.data.auth_key
}
resolve(res);
})
}
})
} else {
console.log('获取用户登陆态失败!' + res.errMsg);
var res = {
status: 300,
data: '错误'
}
reject('error');
}
}
})
});
},
})
//index.js
onLoad: function () {
app.getAuthKey().then(function (res) {
console.log(res);
if (res.status == 200){
var auth_key = res.data;
app.func.req('/api/v1/image/theme-list', {
page: 1,
auth_key: auth_key
}, function (res) {
var page = that.data.pageValue + 1;
that.setData({
images: res.data,
pageValue: page
});
});
}else{
console.log(res.data);
}
});