亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 課堂 > 小程序 > 正文

小程序開發中如何使用async-await并封裝公共異步請求的方法

2020-03-21 16:03:04
字體:
來源:轉載
供稿:網友

前言

在平常的項目開發中肯定會遇到同步異步執行的問題,還有的就是當執行某一個操作依賴上一個執行所返回的結果,那么這個時候你會如何解決這個問題呢;

1.是用settimeout讓它異步執行,顯然這只是讓它加入異步任務隊列中去執行,但并不能保證等待其返回結果再去執行另一個操作。

2.還是自己封裝callback函數?那樣就會陷入所謂的回調地獄,代碼層層嵌套,環環相扣,邏輯稍微復雜就會很難去維護。

3.當然es6中的promise倒是很好的解決了這樣的問題,再配合es7的async和await就更完美了,await返回的也是一個promise對象,這個關于promise和async,await的使用方法就不說了。

實現方案

首先小程序目前還是不支持es7的async和await的,那么如何讓它支持呢

1、點擊下載 

regenerator,并把下載好的runtime.js文件夾放到自己小程序的utils目錄下,包總共才20kb多,體積很小的。

小程序開發,async-await,封裝,異步請求

2、在需要調的地方引入 import regeneratorRuntime from '../../utils/runtime.js'

3、如何封裝并使用

封裝:

const postData = async function(url, data) { wx.showLoading({ title: '加載中', }) let promiseP = await new Promise(function(resolve, reject) { wx.request({  url: baseUrl + url,  data: data,  method: 'POST',  header: {  'content-type': 'application/json',  'access-token': wx.getStorageSync('token')  },  success: function(res) {  wx.hideLoading();  if (res.statusCode === 200) {   resolve(res)  } else {   reject(res.data)  }  },  fail: function(err) {  wx.hideLoading();  reject(err)  if (err.code === 401) {}  } }) }) return promiseP}module.exports = { postData}

使用:

import regeneratorRuntime from '../../utils/runtime.js';const app = getApp(),   postData = require('../../service/koalaApi.js');async demo() { await postData(app.globalData.baseUrl + '/test',{ data: {} }).then((res) => { console.log(res) })}

下面進行了更完善的一個封裝,包括各種錯誤判斷的處理和簡化,通過傳參的方式,來靈活調用

// 當前hostconst url_host = require('API.js').host // 當前版本const currentVersion = require('util.js').currentVersion // 當前路徑import { currentPagePath } from 'util.js' // 調用fetch方法,然后依次鏈式傳入// url, method, header, data, loading(是否顯示loading) function fetch(url, method, header, data, loading) { // 判斷給服務端傳遞undefined的問題 let fetchP = new Promise(function (resolve, reject) { if (loading) {  wx.showLoading({  icon: 'loading'  }) } if(data && data.unionId && typeof data.unionId === "undefined"){  wx.hideLoading()  return reject({  ok:false,  error: 'unionId -> ' + typeof data.unionId  }); } wx.request({  url: url_host + url,  method: method ? method : 'GET',  header: {  'content-type': 'application/json', // 默認值   'version': currentVersion,  'pagePath': currentPagePath()  },  data: data,  success: function (res) {  if (res.statusCode < 500) {   resolve(res.data)  } else {   showError()   reject(res.data)  }  },  fail: function (err) {  showError()  reject(err)  },  complete: function (comp) {  if (loading) {   wx.hideLoading()  }  } }) }) return fetchP}// 服務器開小差了function showError () { wx.hideLoading() // 獲取頭文件路徑 wx.navigateTo({ url: '/pages/serverError/serverError', })}module.exports = { fetch}

思考

1、為什么引入regeneratorRuntime,就能夠使用async/await?不需要配合babel嗎?

2、regeneratorRuntime都做了什么?

總結

1、首先先明白babel和polyfill分別干啥的;

Babel 是一個廣泛使用的轉碼器,Babel 默認只轉換新的 JavaScript 句法,而不轉換新的 API。

例如,Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise 等全局對象,以及一些定義在全局對象上的方法(比如 Object.assign)都不會轉譯。

如果想使用這些新的對象和方法,必須使用 babel-polyfill,為當前環境提供一個墊片。

2、Polyfill用于實現瀏覽器并不支持的原生API的代碼。

3、在明白上面的意思之后,還需要明白的是,babel-polyfill是一股腦把全部都給你添加到js文件中,而現在的runtime將會判斷你哪些需要加載的,有選擇性的進行加載,并且后者也不會污染全局變量。在這里regeneratorRuntime最終轉化成es6的generator來用的。具體的可以自己去下babel官網,輸入相關代碼可以看下最終轉換后的代碼。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久久久久尿| 久久久久久久久久久久av| 欧美乱大交xxxxx另类电影| 国产欧美一区二区白浆黑人| 亚洲人成在线观看网站高清| 日韩精品在线观看一区二区| 国产成人精品一区二区在线| 51精品国产黑色丝袜高跟鞋| 日韩中文字幕在线看| 亚洲欧美日韩在线高清直播| 日韩av在线不卡| 亚洲综合日韩在线| 欧美丝袜第一区| 欧美激情精品久久久久久久变态| 国产精品高潮呻吟久久av无限| 成人免费网视频| 欧美精品福利在线| 亚洲国产美女久久久久| 亚洲人成电影在线| 日韩久久午夜影院| 国产主播欧美精品| 国产成人小视频在线观看| xxx成人少妇69| 欧美亚洲伦理www| 久久精品久久久久久| 97成人超碰免| 国产精品一区二区三区久久| 国产精品视频一区国模私拍| 欧美人与性动交| www.日韩.com| 91美女福利视频高清| 日韩av不卡电影| 伊人亚洲福利一区二区三区| 久久激情视频免费观看| 日韩美女免费视频| 亚洲欧美成人在线| 日韩av在线影院| 欧美成人网在线| 欧美日韩亚洲一区二区| 久久人人爽国产| 欧美xxxx做受欧美.88| 国产亚洲视频中文字幕视频| 国产美女精彩久久| 欧美成人免费视频| 日韩激情av在线免费观看| 成人国产在线视频| 萌白酱国产一区二区| 亚洲综合精品一区二区| 精品在线小视频| 久久精品国产久精国产思思| 午夜免费在线观看精品视频| 欧美视频在线观看免费| 国产精品一区二区女厕厕| 久久久久久亚洲精品不卡| 久久免费成人精品视频| 国产视频久久久久久久| 91高清视频免费| 911国产网站尤物在线观看| 黄色成人在线播放| 亚洲精品电影在线观看| 国产成人精品一区二区三区| 国产精品亚洲美女av网站| 国产精品香蕉在线观看| 久久中文字幕国产| 久久精品国产亚洲一区二区| 亚洲欧美国产一区二区三区| 日韩在线视频免费观看| 久久99精品视频一区97| 成人精品aaaa网站| 国产成人小视频在线观看| 国产精品久久久久久久久| 亚洲成人黄色在线| 精品欧美激情精品一区| 91精品国产91久久久久久最新| 亚洲欧美国产精品| 久热精品视频在线观看一区| 成人国产在线视频| 精品中文字幕乱| 国产日韩欧美在线| 亚洲曰本av电影| 91精品国产一区| 日韩欧美黄色动漫| 国产91av在线| 日韩在线观看免费全集电视剧网站| 91精品国产高清自在线| 亚洲夜晚福利在线观看| 亚洲精品一区二三区不卡| 国产精品男女猛烈高潮激情| 亚洲成人精品久久| 亚洲精品www| 欧美日韩中文字幕在线| 久久久精品一区| 精品亚洲国产视频| 国产啪精品视频网站| 国语自产精品视频在免费| 欧美极品在线播放| 亚洲男女自偷自拍图片另类| 77777亚洲午夜久久多人| 欧美色欧美亚洲高清在线视频| 国产精品爽爽ⅴa在线观看| 伊人久久久久久久久久久| 色悠久久久久综合先锋影音下载| 亚洲图片欧洲图片av| 日韩在线视频线视频免费网站| 国产精品mp4| 中文字幕免费精品一区| 国产视频在线观看一区二区| 国产日韩欧美中文在线播放| 精品偷拍各种wc美女嘘嘘| 中文字幕国产亚洲| 国产精品视频xxx| 日韩免费观看高清| 亚洲一区二区三区xxx视频| 欧美一级电影在线| 国内精品美女av在线播放| 亚洲欧美制服中文字幕| 国产精品69av| 亚洲最大福利视频网站| 国产成人aa精品一区在线播放| 亚洲欧美日韩一区二区在线| 欧美乱大交做爰xxxⅹ性3| 在线看欧美日韩| 91精品国产综合久久久久久蜜臀| 海角国产乱辈乱精品视频| 欧美亚洲成人精品| 日本精品久久久久影院| 中文字幕日韩欧美| 国产在线播放不卡| 国产精自产拍久久久久久蜜| 亚洲美女在线看| 亚洲综合日韩在线| 久久国产精品视频| 国产一区二区三区视频在线观看| 国产精品第1页| 国产主播精品在线| 午夜精品久久久久久久男人的天堂| 2018国产精品视频| 国产美女久久精品香蕉69| 九九视频这里只有精品| 成人中文字幕在线观看| 亚洲国产精品久久91精品| 日韩中文理论片| 国产欧美日韩高清| 91po在线观看91精品国产性色| 国产精品久久久999| 亚洲国产精品专区久久| 亚洲欧美国产精品专区久久| 精品亚洲va在线va天堂资源站| 久久青草精品视频免费观看| 国产精品自拍偷拍| 日韩成人免费视频| 亚洲自拍偷拍第一页| 97精品国产91久久久久久| 欧美性猛交xxxx富婆| 91精品视频网站| 久久在线观看视频| 欧美在线国产精品| 欧美性做爰毛片| 国产性色av一区二区| 国产成人综合av| 亚洲欧美日韩视频一区| 久久艹在线视频| 欧美激情女人20p| 日本久久久久久久久久久|