中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序異步處理的示例分析

發布時間:2021-01-30 10:43:19 來源:億速云 閱讀:130 作者:小新 欄目:移動開發

這篇文章主要介紹微信小程序異步處理的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

直接看問題:

微信小程序異步處理的示例分析

然后看打印的結果:

微信小程序異步處理的示例分析

根據上面兩圖可以看出,代碼上先執行的網絡請求,再執行打印的變量,但是從下面打印的結果來看,先出結果的是執行打印變量的函數(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:

微信小程序異步處理的示例分析

調用:

微信小程序異步處理的示例分析

打印結果

微信小程序異步處理的示例分析

這樣就可以了,完結。

以上是“微信小程序異步處理的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

靖边县| 弋阳县| 镇坪县| 洛阳市| 廉江市| 仙桃市| 高邮市| 赤城县| 房山区| 娄底市| 塔河县| 巴中市| 景德镇市| 泽库县| 陆河县| 塘沽区| 柘荣县| 连南| 林口县| 罗定市| 剑川县| 祁连县| 宽甸| 裕民县| 中阳县| 江山市| 桐柏县| 平原县| 建阳市| 商丘市| 舟山市| 清河县| 正宁县| 平塘县| 罗城| 贵定县| 鄢陵县| 鄂托克旗| 永清县| 丰原市| 金门县|