小程序php没执行完,解决微信小程序 app onLaunch异步请求,在没有请求执行完就加载首页了的问题...

今天在调试小程序的过程当中,进了一个坑,程序加载须要先获取用户信息,而后保存到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);

}

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值