亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

小程序開(kāi)發(fā)中如何使用async-await并封裝公共異步請(qǐng)求的方法

 更新時(shí)間:2019年01月20日 10:10:27   作者:小白  
在平常的項(xiàng)目開(kāi)發(fā)中肯定會(huì)遇到同步異步執(zhí)行的問(wèn)題,這篇文章主要介紹了小程序開(kāi)發(fā)中如何使用async-await并封裝公共異步請(qǐng)求的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

在平常的項(xiàng)目開(kāi)發(fā)中肯定會(huì)遇到同步異步執(zhí)行的問(wèn)題,還有的就是當(dāng)執(zhí)行某一個(gè)操作依賴上一個(gè)執(zhí)行所返回的結(jié)果,那么這個(gè)時(shí)候你會(huì)如何解決這個(gè)問(wèn)題呢;

1.是用settimeout讓它異步執(zhí)行,顯然這只是讓它加入異步任務(wù)隊(duì)列中去執(zhí)行,但并不能保證等待其返回結(jié)果再去執(zhí)行另一個(gè)操作。

2.還是自己封裝callback函數(shù)?那樣就會(huì)陷入所謂的回調(diào)地獄,代碼層層嵌套,環(huán)環(huán)相扣,邏輯稍微復(fù)雜就會(huì)很難去維護(hù)。

3.當(dāng)然es6中的promise倒是很好的解決了這樣的問(wèn)題,再配合es7的async和await就更完美了,await返回的也是一個(gè)promise對(duì)象,這個(gè)關(guān)于promise和async,await的使用方法就不說(shuō)了。

實(shí)現(xiàn)方案

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

1、點(diǎn)擊下載

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

2、在需要調(diào)的地方引入 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)
 })
}

下面進(jìn)行了更完善的一個(gè)封裝,包括各種錯(cuò)誤判斷的處理和簡(jiǎn)化,通過(guò)傳參的方式,來(lái)靈活調(diào)用

// 當(dāng)前host
const url_host = require('API.js').host 
// 當(dāng)前版本
const currentVersion = require('util.js').currentVersion 
// 當(dāng)前路徑
import { currentPagePath } from 'util.js' 

// 調(diào)用fetch方法,然后依次鏈?zhǔn)絺魅?
// url, method, header, data, loading(是否顯示loading) 

function fetch(url, method, header, data, loading) {
 // 判斷給服務(wù)端傳遞undefined的問(wèn)題
 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', // 默認(rèn)值 
  '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
}

// 服務(wù)器開(kāi)小差了
function showError () {
 wx.hideLoading()
 // 獲取頭文件路徑
 wx.navigateTo({
 url: '/pages/serverError/serverError',
 })
}

module.exports = {
 fetch
}

思考

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

2、regeneratorRuntime都做了什么?

總結(jié)

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

Babel 是一個(gè)廣泛使用的轉(zhuǎn)碼器,Babel 默認(rèn)只轉(zhuǎn)換新的 JavaScript 句法,而不轉(zhuǎn)換新的 API。

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

如果想使用這些新的對(duì)象和方法,必須使用 babel-polyfill,為當(dāng)前環(huán)境提供一個(gè)墊片。

2、Polyfill用于實(shí)現(xiàn)瀏覽器并不支持的原生API的代碼。

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • javascript HTML5 Canvas實(shí)現(xiàn)圓盤抽獎(jiǎng)功能

    javascript HTML5 Canvas實(shí)現(xiàn)圓盤抽獎(jiǎng)功能

    這篇文章主要為大家詳細(xì)介紹了javascript HTML5 Canvas實(shí)現(xiàn)圓盤抽獎(jiǎng)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行

    詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行"冒煙測(cè)試"的大致流程

    這篇文章主要介紹了詳解使用mocha對(duì)webpack打包的項(xiàng)目進(jìn)行"冒煙測(cè)試"的大致流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • js學(xué)習(xí)總結(jié)_輪播圖之漸隱漸現(xiàn)版(實(shí)例講解)

    js學(xué)習(xí)總結(jié)_輪播圖之漸隱漸現(xiàn)版(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇js學(xué)習(xí)總結(jié)_輪播圖之漸隱漸現(xiàn)版(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • 幾句話帶你理解JS中的this、閉包、原型鏈

    幾句話帶你理解JS中的this、閉包、原型鏈

    在javascript前端開(kāi)發(fā)階段經(jīng)常會(huì)遇到this,閉包,原型鏈知識(shí),那么大家對(duì)這三種的基本知識(shí)理解嗎?今天小編就帶領(lǐng)大家一起學(xué)習(xí)this,閉包,原型鏈的知識(shí),感興趣的朋友一起看看吧
    2016-09-09
  • javascript實(shí)現(xiàn)的右下角彈窗實(shí)例

    javascript實(shí)現(xiàn)的右下角彈窗實(shí)例

    這篇文章主要介紹了javascript實(shí)現(xiàn)的右下角彈窗,實(shí)例分析了javascript實(shí)現(xiàn)右下角彈窗的完整實(shí)現(xiàn)步驟與技巧,需要的朋友可以參考下
    2015-04-04
  • 終于解決了IE8不支持?jǐn)?shù)組的indexOf方法

    終于解決了IE8不支持?jǐn)?shù)組的indexOf方法

    今天,測(cè)試報(bào)過(guò)來(lái)一個(gè)js bug, 在IE8下有個(gè)js錯(cuò)誤,但是在其它瀏覽器下(Firefox, Chrome, IE9)下面都很正常。后來(lái)調(diào)試發(fā)現(xiàn)原因是在IE8下,js數(shù)組沒(méi)有indexOf方法。
    2013-04-04
  • JavaScript iframe數(shù)據(jù)共享接口實(shí)現(xiàn)方法

    JavaScript iframe數(shù)據(jù)共享接口實(shí)現(xiàn)方法

    在iframe與父窗口或者與子窗口傳遞數(shù)據(jù)是一個(gè)麻煩的事情,如果我們能夠?qū)懸粋€(gè)一勞永逸的接口那就再方便不過(guò)了,下面就來(lái)簡(jiǎn)答介紹一下如何實(shí)現(xiàn)此功能,對(duì)js iframe相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • JavaScript實(shí)現(xiàn)下拉列表選擇框

    JavaScript實(shí)現(xiàn)下拉列表選擇框

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)下拉列表選擇框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 原生js獲取left值和top值的三種方法

    原生js獲取left值和top值的三種方法

    下面小編就為大家?guī)?lái)一篇原生js獲取left值和top值的三種方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 在 JavaScript 中用下劃線替換空格的方法

    在 JavaScript 中用下劃線替換空格的方法

    這篇文章主要介紹了在 JavaScript 中用下劃線替換空格的方法,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05

最新評(píng)論