欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解將微信小程序接口Promise化并使用async函數(shù)

 更新時(shí)間:2019年08月05日 15:12:30   作者:Peggy7  
這篇文章主要介紹了詳解將微信小程序接口Promise化并使用async函數(shù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

小程序一直到現(xiàn)在接口還是和剛開始一樣使用的回調(diào)函數(shù)的方式,如果想在小程序中不使用框架的情況下使用Promise+Async怎么辦呢?

2019最新解決方案

1. 將接口Promise化

首先建一個(gè)文件wxPromise.js

const promisify = name => option => {
 return new Promise((resolve, reject) =>
  wx[name]({
   ...option,
   success: resolve,
   fail: reject,
  })
 )
}

const wxPro = new Proxy(wx, {
 get(target, prop) {
  return promisify(prop)
 }
})

export default wxPro

2.使用regeneratorRuntime讓小程序兼容async函數(shù)

github項(xiàng)目regenerator里下載packages/regenerator-runtime/runtime.js。

如果是最新版本的話引入后會(huì)報(bào)一個(gè)錯(cuò)誤:

Function is not a function....

需要手動(dòng)修改源碼:

去掉源碼最后的try-catch語句,并將開頭的var runtime改成var regeneratorRuntime。

如果不想修改則可以直接下載0.13.1版本的源碼。

最后

在想使用的頁(yè)面里引入:

import wxPro from './utils/wxPromise.js'
import regeneratorRuntime from './utils/runtime.js'

//app.js
App({
 async onLaunch() {
  // wxPro.login().then((res) => {
  //  console.log(res)
  // })
  const result = await wxPro.login()
  console.log(result)
 },
 globalData: {
  userInfo: null
 }
})

這樣就可以了,唯一有點(diǎn)麻煩的是每個(gè)要用的頁(yè)面都要引入一次。

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

相關(guān)文章

最新評(píng)論