直接看问题: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);
这样的话,异步函数就能够依次执行了
而后须要使用的那个页面的js里引入prom.js:
调用:
打印结果
这样就能够了,完结。
想了解更多的小程序的知识请添加微信小程序开发交流群:368506119