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


Posted in Javascript onMarch 28, 2019

所述问题:

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

解决方法:

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

方法实现:

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()
{
//需要用到用户编号换取商品信息的接口

}
})

总结:

当然解决异步回调的方法有很多种,不过我在这里只说我认为好用的一种,大家有什么想法也可以一起分享学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery+AJAX实现无刷新下拉加载更多
Jul 03 Javascript
利用CSS3在Angular中实现动画
Jan 15 Javascript
jQuery Easyui学习之datagrid 动态添加、移除editor
Jan 27 Javascript
AngularJs验证重复密码的方法(两种)
Nov 25 Javascript
JavaScript实现的select点菜功能示例
Jan 16 Javascript
微信小程序 合法域名校验出错详解及解决办法
Mar 09 Javascript
详解AngularJS ui-sref的简单使用
Apr 24 Javascript
jQuery Datatable 多个查询条件自定义提交事件(推荐)
Aug 24 jQuery
React Native时间转换格式工具类分享
Oct 24 Javascript
详解react关于事件绑定this的四种方式
Mar 09 Javascript
JavaScript使用递归和循环实现阶乘的实例代码
Aug 28 Javascript
JS手写一个自定义Promise操作示例
Mar 16 Javascript
详解vue使用插槽分发内容slot的用法
Mar 28 #Javascript
详解一个基于套接字实现长连接的express
Mar 28 #Javascript
微信小程序学习笔记之跳转页面、传递参数获得数据操作图文详解
Mar 28 #Javascript
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 #Javascript
深入理解es6块级作用域的使用
Mar 28 #Javascript
详解在网页上通过JS实现文本的语音朗读
Mar 28 #Javascript
详解React服务端渲染从入门到精通
Mar 28 #Javascript
You might like
php数组函数序列之end() - 移动数组内部指针到最后一个元素,并返回该元素的值
2011/10/31 PHP
PHP中开启gzip压缩的2种方法
2015/01/31 PHP
THINKPHP3.2使用soap连接webservice的解决方法
2017/12/13 PHP
很好用的js日历算法详细代码
2013/03/07 Javascript
『jQuery』.html(),.text()和.val()的概述及使用
2013/04/22 Javascript
jQuery获取浏览器中的分辨率实现代码
2013/04/23 Javascript
jQuery ajax dataType值为text json探索分享
2013/09/23 Javascript
使用ajaxfileupload.js实现ajax上传文件php版
2014/06/26 Javascript
Javascript MVC框架Backbone.js详解
2014/09/18 Javascript
jQuery时间轴插件使用详解
2015/07/16 Javascript
浅谈JavaScript中指针和地址
2015/07/26 Javascript
JavaScript必知必会(九)function 说起 闭包问题
2016/06/08 Javascript
BootstrapTable refresh 方法使用实例简单介绍
2017/02/20 Javascript
JS实现页面打印(整体、局部)
2017/08/18 Javascript
seaJs使用心得之exports与module.exports的区别实例分析
2017/10/13 Javascript
微信小程序开发之路由切换页面重定向问题
2018/09/18 Javascript
原生js实现html手机端城市列表索引选择城市
2020/06/24 Javascript
vscode 调试 node.js的方法步骤
2020/09/15 Javascript
Python tkinter事件高级用法实例
2018/01/31 Python
python3 读写文件换行符的方法
2018/04/09 Python
使用 Python ssh 远程登陆服务器的最佳方案
2020/03/06 Python
python3 deque 双向队列创建与使用方法分析
2020/03/24 Python
Python flask框架如何显示图像到web页面
2020/06/03 Python
selenium设置浏览器为headless无头模式(Chrome和Firefox)
2021/01/08 Python
详解CSS3中使用gradient实现渐变效果的方法
2015/08/18 HTML / CSS
HTML5+CSS3模仿优酷视频截图功能示例
2017/01/05 HTML / CSS
欧洲领先的电子和电信零售商和服务提供商:Currys PC World Business
2017/12/05 全球购物
生物技术毕业生自荐信
2013/10/23 职场文书
中式面点餐厅创业计划书
2014/01/29 职场文书
函授药学自我鉴定
2014/02/07 职场文书
志愿者活动总结范文
2014/04/26 职场文书
县委务虚会发言材料
2014/10/20 职场文书
校运会通讯稿
2015/07/18 职场文书
详解Node.js如何处理ES6模块
2021/05/15 Javascript
MySQL创建管理子分区
2022/04/13 MySQL
windows10声卡驱动怎么安装?win10声卡驱动安装操作步骤教程
2022/08/05 数码科技