首页 >

关于微信小程序的异步处理

微信小程序|小程序开发关于微信小程序的异步处理
微信小程序,异步处理
微信小程序-小程序开发
这篇文章主要为大家详细介绍了微信小程序异步处理的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
系统收录源码,vscode连接树莓派,Ubuntu编译sdk,tomcat信息保存,sqlite数据库表格,网络爬虫采集数据的途径,php 777,seo文章编辑招聘,云时代网站源码,asp网页源码下载,二手车配置信息模板lzw
本文实例为大家分享了微信小程序异步处理的具体方法,供大家参考,具体内容如下
本地源码的位置,vscode写csharp,ubuntu如何下载py,idea搭建tomcat,sqlite 条件插入,onethink 插件使用,前端框架怎么用呢,新闻爬虫分析,php 对象与数组,SEO点击软件工程,电影网站源码带自动采集,网页聊天室 代码,h5商城 模板,漂亮注册登录页面模板,后台管理系统 试用,人人商城v3小程序教程lzw
直接看问题:
简单的聊天器源码,vscode 转化编码格式,ubuntu兼容软件,tomcat添加驱动文件,人流爬虫,php 字符串布尔,浙江seo推广优质团队,游戏市场网站源码,购物网站程序模板lzw
关于微信小程序的异步处理

然后看打印的结果:

关于微信小程序的异步处理

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

关于微信小程序的异步处理

调用:

关于微信小程序的异步处理

打印结果

关于微信小程序的异步处理

这样就可以了,完结。


关于微信小程序的异步处理
  • 微信小程序 删除项目工程实现步骤
  • 微信小程序 删除项目工程实现步骤 | 微信小程序 删除项目工程实现步骤 ...

    关于微信小程序的异步处理
  • 微信小程序 循环及嵌套循环的使用
  • 微信小程序 循环及嵌套循环的使用 | 微信小程序 循环及嵌套循环的使用 ...

    关于微信小程序的异步处理
  • 微信小程序开发系列(一)开发准备的详解
  • 微信小程序开发系列(一)开发准备的详解 | 微信小程序开发系列(一)开发准备的详解 ...