微信小程序异步处理

小说:斗牛app那个好玩作者:辛通龙更新时间:2019-01-24字数:15734

纷乱的声音就像是被利刃斩断般嘎然而止。谁能想到,之前还一脸恬淡,优雅自若的唐三,竟然能够释放出这犹如实质般地强横杀气。

跑得快一

对于其他的事情她根本不怎么在意也没兴趣在意,反而是在看到这一幕之后还不着痕迹的帮着娜洁希坦。
提炼出来的九尾查克拉会将我体内的查克拉吞噬掉,虽然我最后的查克拉成为九尾查克拉的养分,加速九尾查克拉的成长速度最后彻底的取代我体内原本所有的查克拉。

纵观整个大明朝,宦官弄权大有人在,从明初开始已经有些苗头,离开驿馆,进入皇城范围,秦王咳嗽一声,“卫公公,可知父皇下旨命我等入京所谓何事?”

微信小程序异步处理


直接看问题:

然后看打印的结果:

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

 

为什么先执行的aafn,并且打印的值没有赋值上?

因为wx.request是一个异步的请求,所以数据请求的同时,可以继续向下执行函数。所以这里值还没有赋值上就开始打印了变量的值;

 

这种情况,怎么解决呢?

方法一: 

嵌套

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

然后运行结果

这里就取到值了

但是如果逻辑很复杂,需要用到很多层异步,就像这样:

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去包装这些API,但是这个还是比较麻烦的。不过,小程序的API的参数格式都比较统一,只接受一个object参数,回调都是在这个参数中设置,所以,这为了统一处理提供了便利,写一个工具方法,来完成这样的工作
首先需要引用一个叫bluebird.js的文件;
进入bluebird官网下载:

 

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

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

调用:

 

打印结果

 这样就可以了,完结。

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

当前文章:http://zxqss.com/content/2018-11/23/content_74775.html

发布时间:2019-01-24 04:32:05

ucjizz 棋牌牛牛下载安装 每天赠送6元的斗地主 网上棋牌可以换现金 闲来贵州麻将作弊器源 星辰棋牌下载 买房为什么不能买边户 至尊棋牌赢三张漏洞

编辑:辛开平顺

我要说两句: (0人参与)

发布