您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)微信小程序中如何使用Async-await方法異步請(qǐng)求變?yōu)橥秸?qǐng)求方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
微信小程序中有些 Api 是異步的,無(wú)法直接進(jìn)行同步處理。例如:wx.request、wx.showToast、wx.showLoading等。如果需要同步處理,可以使用如下方法:
注意:
Async-await方法屬于ES7語(yǔ)法,在小程序開(kāi)發(fā)工具中如果勾選es6轉(zhuǎn)es5, 會(huì)報(bào)錯(cuò):
ReferenceError: regeneratorRuntime is not defined
避免報(bào)錯(cuò),可以引入 regenerator
在根目錄下創(chuàng)建 lib 文件夾,并將 https://github.com/facebook/regenerator/tree/master/packages 里面的 regenerator-runtime 文件夾放進(jìn)去。
然后在使用async-awiat的頁(yè)面中引入:
// pages/list/list.js const regeneratorRuntime = require('../../lib/regenerator-runtime/runtime')
同步處理異步請(qǐng)求
在根目錄下新建api文件夾,里面新建index.js
// request get 請(qǐng)求 const getData = (url, param) => { return new Promise((resolve, reject) => { wx.request({ url: url, method: 'GET', data: param, success (res) { console.log(res) resolve(res.data) }, fail (err) { console.log(err) reject(err) } }) }) } // request post 請(qǐng)求 const postData = (url, param) => { return new Promise((resolve, reject) => { wx.request({ url: url, method: 'POST', data: param, success (res) { console.log(res) resolve(res.data) }, fail (err) { console.log(err) reject(err) } }) }) } // loading加載提示 const showLoading = () => { return new Promise((resolve, reject) => { wx.showLoading({ title: '加載中...', mask: true, success (res) { console.log('顯示loading') resolve(res) }, fail (err) { reject(err) } }) }) } // 關(guān)閉loading const hideLoading = () => { return new Promise((resolve) => { wx.hideLoading() console.log('隱藏loading') resolve() }) } module.exports = { getData, postData, showLoading, hideLoading }
在入口文件 app.js 中引入:
//app.js const api = require('./api/index') App({ onLaunch: function () { }, // 全局?jǐn)?shù)據(jù)中暴露api globalData: { api } })
在需要使用api 的頁(yè)面中處理如下:
// pages/list/list.js const app = getApp() const api = app.globalData.api Page({ onLoad () { this.init() }, // 初始化 async init () { await api.showLoading() // 顯示loading await this.getList() // 請(qǐng)求數(shù)據(jù) await api.hideLoading() // 等待請(qǐng)求數(shù)據(jù)成功后,隱藏loading }, // 獲取列表 getList () { return new Promise((resolve, reject) => { api.getData('http://127.0.0.1:3000/list', { x: '', y: '' }).then((res) => { this.setData({ list: res }) console.log(res) resolve() }) .catch((err) => { console.error(err) reject(err) }) }) }, })
感謝各位的閱讀!關(guān)于“微信小程序中如何使用Async-await方法異步請(qǐng)求變?yōu)橥秸?qǐng)求方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。