微信小程序异步处理
2017-11-10 11:50
225 查看
直接看问题:
然后看打印的结果:
根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(aafn函数),再打印出网络请求success的回调里返回的数据和赋值后的变量的值;
为什么先执行的aafn,并且打印的值没有赋值上?
因为wx.request是一个异步的请求,所以数据请求的同时,可以继续向下执行函数。所以这里值还没有赋值上就开始打印了变量的值;
这种情况,怎么解决呢?
方法一:
嵌套
在wx.request的success回调里执行aafn函数
然后运行结果
这里就取到值了
但是如果逻辑很复杂,需要用到很多层异步,就像这样:
这样代码看起来就很不好看,代码的可读性和可维护性就不好了
那怎么解决这个问题呢?Promise这种概念的产生,很好地解决了这一切,Promise是什么?这里我就不多说了有兴趣的自己去看一看,Promise介绍链接
先看看Promise的方式:
调用
这样的话,异步函数就可以依次执行了
微信小程序的异步API怎么支持Promise呢?(注:现在小程序已经支持Promise了,可以直接使用,不用引用JS这么麻烦!!!2017-12-16)
我们可以一个一个的用Promise去包装这些API,但是这个还是比较麻烦的。不过,小程序的API的参数格式都比较统一,只接受一个object参数,回调都是在这个参数中设置,所以,这为了统一处理提供了便利,写一个工具方法,来完成这样的工作
首先需要引用一个叫bluebird.js的文件;
进入bluebird官网下载:
这个好像是不能下载的,但是你可以点击进入,然后复制,在小程序里创建一个js文件,将代码复制到这个js里面,然后引用
然后再写一个JS,里面写工具方法:
下面是prom.js
然后需要使用的那个页面的js里引入prom.js:
调用:
打印结果
这样就可以了,完结。
想了解更多的小程序的知识请添加微信小程序开发交流群:368506119
然后看打印的结果:
根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(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了,可以直接使用,不用引用JS这么麻烦!!!2017-12-16)
我们可以一个一个的用Promise去包装这些API,但是这个还是比较麻烦的。不过,小程序的API的参数格式都比较统一,只接受一个object参数,回调都是在这个参数中设置,所以,这为了统一处理提供了便利,写一个工具方法,来完成这样的工作
首先需要引用一个叫bluebird.js的文件;
进入bluebird官网下载:
这个好像是不能下载的,但是你可以点击进入,然后复制,在小程序里创建一个js文件,将代码复制到这个js里面,然后引用
然后再写一个JS,里面写工具方法:
下面是prom.js
然后需要使用的那个页面的js里引入prom.js:
调用:
打印结果
这样就可以了,完结。
想了解更多的小程序的知识请添加微信小程序开发交流群:368506119
相关文章推荐
- 微信小程序中使用Promise进行异步流程处理
- 微信小程序之支付后调用SDK的异步通知及验证处理订单
- 微信小程序 es6-promise.js封装请求与处理异步进程
- 微信小程序之支付后调用SDK的异步通知及验证处理订单方法
- 微信小程序利用co处理异步流程的方法教程
- 微信小程序中使用Promise进行异步流程处理的实例详解
- 微信小程序异步处理详解
- 微信小程序 es6-promise.js封装请求 处理异步进程
- 微信小程序 异步请求拿数据+使用外部js库
- 微信小程序处理用户拒绝授权情况及微信登录,登录保存等系列解决方案
- 微信小程序目录结构、事件处理、网络请求
- 微信小程序实例:image组件的binderror事件处理
- Javascript escape 解决 Jquery Ajax 异步请求 URL中文传参乱码问题 一般处理程序Handler获取参数
- php处理微信小程序wx.uploadFile(OBJECT)发送过来的文件
- 创建异步 HTTP 处理程序
- 创建异步 HTTP 处理程序
- 【微信小程序】异步请求,权重,自适应宽度并折行,颜色渐变,绝对定位
- PHP微信APP支付,下单,处理异步回调
- Spring MVC 异步处理请求,提高程序性能