小程序开发

微信小程序开发异步处理教程

编辑时间:2019-08-24 15:32  浏览次数:浏览次数
摘要:微信小程序是通过wx.request进行异步处理,使用起来确实有很多不方便,不能忍,幸好小程序是支持ES6语法的,所以可以使用promise稍加改造。
小程序开发异步处理 微信小程序是通过wx.request进行异步处理,使用起来确实有很多不方便,不能忍,幸好小程序是支持ES6语法的,所以可以使用promise稍加改造。 Page({ data: {  myData: }, // loadMyData函数用于打印myData的值  loadMyData () {  console.log(获取到的数据为: + this.data.myData) },  // 生命周期函数onload用于监听页面加载 onload: function () {  wx.request({ url: https://api,  // 某个api接口地址  success: res => {  console.log(res.data)  this.setData({  myData: res.data  })  console.log(this.data.myData)  } })  // 调用之前的函数  this.loadMyData()  }  }) 然后我们会在控制台到这样的结果:
小程序开发异步处理 这其实是一个很简单的异步问题,wx.request是异步请求,JS不会等待wx.request执行完毕再往下执行,所以JS按顺序会先执行this.loadMyData(),等服务器返回数据以后,loadMyData()早就执行完了,当然也就没有拿到值啦。 其实我们在同步流程中才说“返回”,异步没有“返回”这个概念(或者说异步返回是没有意义的),异步对应的是“回调”,也就是说,对于一个异步函数,我们应该传入一个“回调函数”来接收结果。
初步解决:通过回调接收结果 最简单的解决方案,就是把需要使用异步数据的函数写在回调里: onload: function () {  wx.request({  url: https://api, // 某个api接口地址  success: res => {  console.log(res.data)  this.setData({  myData: res.data  })  console.log(this.data.myData)  // 把使用数据的函数写在回调函数success中  this.loadMyData()  }  })  } 而我们发现,微信小程序的网络请求wx.request,也正是这种依靠回调函数的形式,类似于以前的$.ajax,它在逻辑复杂、页面执行顺序要求多的情况下,弊端也是很明显的。
不过好在小程序支持ES6,我们可以尽情地拥抱Promise! 使用Promise包装wx.request Promise这东西简单说来就是,它可以将异步的执行逻辑和结果处理分离,摒弃了一层又一层的回调嵌套,使得处理逻辑更加清晰。
/**  * requestPromise用于将wx.request改写成Promise方式  * @param:{string} myUrl 接口地址  * @return: Promise实例对象  */  const requestPromise = myUrl => { // 返回一个Promise实例对象  return new Promise((resolve, reject) => {  wx.request({ url: myUrl,  success: res => resolve(res)  }) }) } // 我把这个函数放在了utils.js中,这样在需要时可以直接引入  module.exports = requestPromise 现在再使用试试: // 引用模块const utilApi = require(../../utils/util.js) Page({ ...  // 生命周期函数onload用于监听页面加载  onLoad: function () { utilApi.requestPromise(https://www.bilibili.com/index/ding.json)  // 使用.then处理结果  .then(res => {  console.log(res.data) this.setData({ myData: res.data })  console.log(this.data.myData)  this.loadMyData()  })  }  })   结果和使用回调函数一致。
当有多个异步请求时,直接不断地.then(fn)去处理即可,逻辑清晰。 当然,这里只是写了一个最简单的Promise函数,还不完整。更完整的Promise化wx.request,等以后业务需要再完善吧。另外各种小程序开发框架也都有了现成的promise化API,拿来即用。

本文地址:https://www.webbj.cn/operation/xcx1886.html

免责声明:我司网站转载此文,不代表本网的观点和立场。不以盈利为目的,如有侵犯公司或个人权益,请联系QQ:451521464沟通,我司会第一时间删除文章。 思捷智联是北京小程序开发公司,欢迎咨询免费获取思维导图!
推荐阅读
思捷智联

思捷智联是一家2009年成立于北京的IT外包公司,我们致力于为企业提供app软件开发和微信小程序开发服务。公司成立10年来,我们为民政部、方正电子、神州数码、联想控股、壹基金、首钢集团、北京大学、北京师范大学、今麦郎、丰汇租赁、万通控股等上百家企业提供了IT外包服务。我们努力实现每一位客户的托付,为客户创造实在的效益,让您与梦想走得更近。

微信咨询

扫描微信二维码
同市场经理沟通需求

感受专业服务,从来电咨询开始
136-6130-7020