小程序php没执行完,关于微信小程序的异步处理

这篇文章主要为大家详细介绍了微信小程序异步处理的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了微信小程序异步处理的具体方法,供大家参考,具体内容如下

直接看问题:

ae35403c61d7657a181f90ad841b8af6.png

然后看打印的结果:

8e24f810f529c3e0cb813a75b9d2a85d.png

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

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

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

这种情况,怎么解决呢?

方法一:

嵌套

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

17e786a4dca0b90ce1ea76e489693a01.png

然后运行结果

5eee41247d278506f6326bd229b6ad36.png

这里就取到值了

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

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官网下载:

00117baa9066f3792401f2ae824537c8.png

这个好像是不能下载的,但是你可以点击进入,然后复制,在小程序里创建一个js文件,将代码复制到这个js里面,然后引用。

然后再写一个JS,里面写工具方法:

4a8a43376aa6e7bbd7e0fffc5aac20b8.png

下面是prom.js

b9ded5e809f013c5d53f74efe727727a.png

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

b111be1be1f0d85c33485047372575c6.png

调用:

03ae356b288e140127a26b97cc295c64.png

打印结果

10a6aa7ed2075a769eba03de6afe9cdf.png

这样就可以了,完结。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值