微信小程序之onLaunch与onload异步问题详解
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了微信小程序之onLaunch与onload异步问题详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
所述问题
前端时间开发了一个微信小程序商城项目,因为这个项目我们的需求是进入小程序就通过wx.login({}) 这个api进行用户登录,获取系统后台的用户基本信息。再此之前,一直以为微信小程序中的App.js 中onLaunch (小程序初始化完成执行该方法)方法比其他页面的的 onload 方法要先执行。那么问题就来了,我每次进入小程序首页的时候有时候会先执行onlaunch方法,有时又会先执行首页的onload的方法,经过确定,在微信小程序中这两个方法并没有执行先后的顺序,因为他们都是异步执行的。开发过微信小程序的开发者都知道微信请求数据都是异步执行的,如在同一个onload写两个请求数据的方法,它不一定会按照先后顺序去执行,这就是传说中的异步地狱了。
解决方法
,我既然知道这个执行顺序是由于微信小程序的异步执行请求原因导致的。我们可以使用Promise 来解决异步编程问题啦。我的解决方法是,我是在app.js 中定义了一个全局方法,用来登录小程序请求用户信息的接口,每次进入首页的时候先判断我是否已有用户信息缓存,假如不存在那么请求app.js中的全局方法进行数据获取。在这里我就不详细介绍Promise 的基本用法了,因为阮一峰已经将的非常详细了,大家可以点击查看【 】。
方法实现
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({ suess: function(res) { if (res.code) { console.log("用户登录授权code为" + res.code); //调用wx.request请求传递code凭证换取用户openid,并获取后台用户信息 wx.request({ url: 'https://.xxxx.xxx.api', // 后台请求用户信息方法【注意,此处必须为https数字加密证书】 data: { code: res.code //code凭证 }, header: { 'content-type': 'application/json' // 默认值 }, suess(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: '系统错误' }) }, plete: () => { } //plete接口执行后的回调函数,无论成功失败都会调用 }) } 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() { //需要用到用户编号换取商品信息的接口 } })
解决异步回调的方法有很多种,不过我在这里只说我认为好用的一种,大家有什么想法也可以一起分享学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程