源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

微信小程序异步处理详解

  • 时间:2021-06-15 18:45 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:微信小程序异步处理详解
本文实例为大家分享了微信小程序异步处理的具体方法,供大家参考,具体内容如下 直接看问题: [img]http://files.jb51.net/file_images/article/201711/201711101536557.png[/img] 然后看打印的结果: [img]http://files.jb51.net/file_images/article/201711/201711101536558.png[/img] 根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(aafn函数),再打印出网络请求success的回调里返回的数据和赋值后的变量的值; [b]为什么先执行的aafn,并且打印的值没有赋值上?[/b] 因为wx.request是一个异步的请求,所以数据请求的同时,可以继续向下执行函数。所以这里值还没有赋值上就开始打印了变量的值; [b]这种情况,怎么解决呢?[/b] [b]方法一:[/b] 嵌套 在wx.request的success回调里执行aafn函数 [img]http://files.jb51.net/file_images/article/201711/201711101536569.png[/img] 然后运行结果 [img]http://files.jb51.net/file_images/article/201711/2017111015365610.png[/img] 这里就取到值了 但是如果逻辑很复杂,需要用到很多层异步,就像这样:
asyncFn1(function(){
 //...
 asyncFn2(function(){
  //...
  asyncFn3(function(){
   //...
   asyncFn4(function(){
    //...
    asyncFn5(function(){
      //...
    });
   });
  });
 });
});

这样代码看起来就很不好看,代码的可读性和可维护性就不好了 那怎么解决这个问题呢?Promise这种概念的产生,很好地解决了这一切,Promise是什么?这里我就不多说了有兴趣的自己去看一看,[url=http://es6.ruanyifeng.com/]Promise介绍链接[/url] 先看看Promise的方式:
function asyncFn1(){
 return new Promise(function (resolve, reject) {
  //...
 })
}

// asyncFn2,3,4,5也实现成跟asyncFn1一样的方式...

调用
asyncFn1()
 .then(asyncFn2)
 .then(asyncFn3)
 .then(asyncFn4)
 .then(asyncFn5);

这样的话,异步函数就可以依次执行了 微信小程序的异步API怎么支持Promise呢?我们可以一个一个的用Promise去包装这些API,但是这个还是比较麻烦的。不过,小程序的API的参数格式都比较统一,只接受一个object参数,回调都是在这个参数中设置,所以,这为了统一处理提供了便利,写一个工具方法,来完成这样的工作 首先需要引用一个叫bluebird.js的文件; 进入[url=http://bluebirdjs.com/docs/getting-started.html]bluebird官网[/url]下载: [img]http://files.jb51.net/file_images/article/201711/2017111015365611.png[/img] 这个好像是不能下载的,但是你可以点击进入,然后复制,在小程序里创建一个js文件,将代码复制到这个js里面,然后引用。 然后再写一个JS,里面写工具方法: [img]http://files.jb51.net/file_images/article/201711/2017111015365612.png[/img] 下面是prom.js [img]http://files.jb51.net/file_images/article/201711/2017111015365613.png[/img] 然后需要使用的那个页面的js里引入prom.js: [img]http://files.jb51.net/file_images/article/201711/2017111015365614.png[/img] 调用: [img]http://files.jb51.net/file_images/article/201711/2017111015365615.png[/img] 打印结果 [img]http://files.jb51.net/file_images/article/201711/2017111015365616.png[/img] 这样就可以了,完结。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部