91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序中如何使用Async-await方法異步請求變為同步請求方法

發布時間:2021-08-10 13:15:16 來源:億速云 閱讀:1022 作者:小新 欄目:web開發

這篇文章給大家分享的是有關微信小程序中如何使用Async-await方法異步請求變為同步請求方法的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

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

注意:

Async-await方法屬于ES7語法,在小程序開發工具中如果勾選es6轉es5, 會報錯:

ReferenceError: regeneratorRuntime is not defined

避免報錯,可以引入 regenerator

在根目錄下創建 lib 文件夾,并將 https://github.com/facebook/regenerator/tree/master/packages 里面的 regenerator-runtime 文件夾放進去。

然后在使用async-awiat的頁面中引入:

// pages/list/list.js

const regeneratorRuntime = require('../../lib/regenerator-runtime/runtime')

微信小程序中如何使用Async-await方法異步請求變為同步請求方法

同步處理異步請求

在根目錄下新建api文件夾,里面新建index.js

// request get 請求
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 請求
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)
  }
 })
 })
}

// 關閉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 () {
 
 },
 // 全局數據中暴露api
 globalData: { 
 api
 }
})

在需要使用api 的頁面中處理如下:

// 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() // 請求數據
 await api.hideLoading() // 等待請求數據成功后,隱藏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)
  })
 })
 },
 
})

感謝各位的閱讀!關于“微信小程序中如何使用Async-await方法異步請求變為同步請求方法”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

获嘉县| 会同县| 酉阳| 濉溪县| 渝北区| 梁平县| 建平县| 时尚| 宿松县| 麻江县| 阿拉善右旗| 黑水县| 屏东县| 嘉定区| 平昌县| 张家川| 内江市| 买车| 苏尼特右旗| 冕宁县| 高台县| 塔城市| 阿瓦提县| 高尔夫| 时尚| 沙田区| 安多县| 纳雍县| 益阳市| 启东市| 五家渠市| 遂宁市| 泉州市| 梁河县| 九江市| 徐水县| 商城县| 博客| 高密市| 盖州市| 襄樊市|