微信小程序异步处理

 

直接看问题:html

而后看打印的结果:es6

根据上面两图能够看出,代码上先执行的网络请求,再执行打印的变量,可是从下面打印的结果来看,先出结果的是执行打印变量的函数(aafn函数),再打印出网络请求success的回调里返回的数据和赋值后的变量的值;小程序

 

为何先执行的aafn,而且打印的值没有赋值上?微信小程序

由于wx.request是一个异步的请求,因此数据请求的同时,能够继续向下执行函数。因此这里值尚未赋值上就开始打印了变量的值;promise

 

这种状况,怎么解决呢?微信

方法一: 网络

嵌套异步

在wx.request的success回调里执行aafn函数async

而后运行结果函数

这里就取到值了

可是若是逻辑很复杂,须要用到不少层异步,就像这样:

asyncFn1(function(){
  //...
  asyncFn2(function(){
    //...
    asyncFn3(function(){
      //...
      asyncFn4(function(){
        //...
        asyncFn5(function(){
           //...
        });
      });
    });
  });
});

 

 

 这样代码看起来就很很差看,代码的可读性和可维护性就很差了

那怎么解决这个问题呢?Promise这种概念的产生,很好地解决了这一切,Promise是什么?这里我就很少说了有兴趣的本身去看一看,Promise介绍连接

先看看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了,能够直接使用,不用引用JS这么麻烦!!!2017-12-16
咱们能够一个一个的用Promise去包装这些API,可是这个仍是比较麻烦的。不过,小程序的API的参数格式都比较统一,只接受一个object参数,回调都是在这个参数中设置,因此,这为了统一处理提供了便利,写一个工具方法,来完成这样的工做
首先须要引用一个叫bluebird.js的文件;
进入 bluebird官网下载:

 

 这个好像是不能下载的,可是你能够点击进入,而后复制,在小程序里建立一个js文件,将代码复制到这个js里面,而后引用
而后再写一个JS,里面写工具方法:
 
下面是prom.js

而后须要使用的那个页面的js里引入prom.js:

调用:

 

打印结果

 这样就能够了,完结。

 想了解更多的小程序的知识请添加微信小程序开发交流群:368506119

相关文章
相关标签/搜索