• 微信小程序异步处理


    直接看问题:

    然后看打印的结果:

    根据上面两图可以看出,代码上先执行的网络请求,再执行打印的变量,但是从下面打印的结果来看,先出结果的是执行打印变量的函数(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

  • 相关阅读:
    Java 注解
    java 编码设计细节
    快捷键大全
    java 常用方法
    用SelectSingleNode()方法查找xml节点一直返回null
    未能加载文件或程序集“microsoft.Build.Engine, Version=3.5.0.0,...”或它的摸一个依赖项。
    引用dll出现了黄色感叹号
    保持控件和容器之间的相对位置
    DataGridView中EnditCommit()调用之后,单元格的内容被全选了,每次输入都要鼠标点击定位到最后才能继续输入
    访问DataGridView的Rows报了OutOfIndexRangeException错误
  • 原文地址:https://www.cnblogs.com/xjwy/p/7813859.html
Copyright © 2020-2023  润新知