国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 熱點(diǎn) > 微信 > 正文

微信小程序中使用Async-await方法異步請(qǐng)求變?yōu)橥秸?qǐng)求方法

2024-07-22 01:18:53
字體:
供稿:網(wǎng)友

微信小程序中有些 Api 是異步的,無法直接進(jìn)行同步處理。例如:wx.request、wx.showToast、wx.showLoading等。如果需要同步處理,可以使用如下方法:

注意:

Async-await方法屬于ES7語法,在小程序開發(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的頁面中引入:

// pages/list/list.jsconst 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)閉loadingconst 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 的頁面中處理如下:

// pages/list/list.jsconst app = getApp()const api = app.globalData.apiPage({  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)  }) }) }, })

參考:http://m.survivalescaperooms.com/article/158645.htm

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 会东县| 孟村| 上犹县| 五家渠市| 天柱县| 大姚县| 长寿区| 连平县| 玉树县| 抚顺市| 巴彦县| 福州市| 珠海市| 曲靖市| 陆良县| 泰兴市| 安西县| 晴隆县| 昭觉县| 合肥市| 寻甸| 博爱县| 偏关县| 城口县| 乌海市| 新丰县| 金塔县| 山东| 公主岭市| 济源市| 兖州市| 江安县| 英德市| 新乡县| 晴隆县| 汪清县| 越西县| 嘉善县| 瓦房店市| 衡山县| 济源市|