成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專(zhuān)欄INFORMATION COLUMN

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

why_rookie / 2895人閱讀

摘要:實(shí)現(xiàn)方案首先小程序目前還是不支持的和的,那么如何讓它支持呢點(diǎn)擊下載,并把下載好的文件夾放到自己小程序的目錄下,包總共才多,體積很小的。如果想使用這些新的對(duì)象和方法,必須使用,為當(dāng)前環(huán)境提供一個(gè)墊片。用于實(shí)現(xiàn)瀏覽器并不支持的原生的代碼。

前言

在平常的項(xiàng)目開(kāi)發(fā)中肯定會(huì)遇到同步異步執(zhí)行的問(wèn)題,還有的就是當(dāng)執(zhí)行某一個(gè)操作依賴(lài)上一個(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)換后的代碼。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/101206.html

相關(guān)文章

  • 小程開(kāi)發(fā)技巧總結(jié)

    摘要:前言最近公司要開(kāi)發(fā)一款電商小程序,匆忙看了一遍文檔就開(kāi)始干活了。整體開(kāi)發(fā)體驗(yàn)個(gè)人感覺(jué)不太好,特別是如果之前習(xí)慣了開(kāi)發(fā),突然去開(kāi)發(fā)小程序,感覺(jué)很雞肋。 前言 最近公司要開(kāi)發(fā)一款電商小程序,匆忙看了一遍文檔就開(kāi)始干活了。整體開(kāi)發(fā)體驗(yàn)個(gè)人感覺(jué)不太好,特別是如果之前習(xí)慣了Vue開(kāi)發(fā),突然去開(kāi)發(fā)小程序,感覺(jué)很雞肋。以下是我在開(kāi)發(fā)中遇到的一些問(wèn)題以及解決方法的總結(jié),僅供參考 引入iconfont ...

    Wuv1Up 評(píng)論0 收藏0
  • 美團(tuán)小程框架mpvue入門(mén)教程

    摘要:美團(tuán)小程序框架入門(mén)教程自打?qū)懥嗣缊F(tuán)小程序框架蹲坑指南一發(fā)不可收拾,今天趁周末空閑,來(lái)寫(xiě)個(gè)沒(méi)朋友的簡(jiǎn)單入門(mén)教程,本教程只針對(duì)新手,老鳥(niǎo)勿噴。 美團(tuán)小程序框架mpvue入門(mén)教程 自打?qū)懥?美團(tuán)小程序框架mpvue蹲坑指南,一發(fā)不可收拾,今天趁周末空閑,來(lái)寫(xiě)個(gè)mpvue(沒(méi)朋友)的簡(jiǎn)單入門(mén)教程,本教程只針對(duì)新手,老鳥(niǎo)勿噴。 另外,我還專(zhuān)門(mén)為本文做了一個(gè)簡(jiǎn)單的項(xiàng)目,如果懶得從頭開(kāi)始搭項(xiàng)目的童鞋...

    YorkChen 評(píng)論0 收藏0
  • 一次基于mpvue的小程開(kāi)發(fā)及上線實(shí)戰(zhàn)

    摘要:一起打車(chē)吧微信小程序依然是一個(gè)玩具般的存在,僅供自己學(xué)習(xí)和探索,當(dāng)然也歡迎各位讀者能夠貢獻(xiàn)代碼,參與開(kāi)發(fā) 小程序名稱(chēng):一起打車(chē)吧 項(xiàng)目地址:客戶(hù)端:https://github.com/jrainlau/t... 服務(wù)端:https://github.com/jrainlau/t... 小程序二維碼:showImg(https://segmentfault.com/img/bV80...

    freewolf 評(píng)論0 收藏0
  • 一次基于mpvue的小程開(kāi)發(fā)及上線實(shí)戰(zhàn)

    摘要:一起打車(chē)吧微信小程序依然是一個(gè)玩具般的存在,僅供自己學(xué)習(xí)和探索,當(dāng)然也歡迎各位讀者能夠貢獻(xiàn)代碼,參與開(kāi)發(fā) 小程序名稱(chēng):一起打車(chē)吧 項(xiàng)目地址:客戶(hù)端:https://github.com/jrainlau/t... 服務(wù)端:https://github.com/jrainlau/t... 小程序二維碼:showImg(https://segmentfault.com/img/bV80...

    miqt 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<