日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
微信小程序中如何使用Async-await方法異步請求變?yōu)橥秸埱蠓椒?創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)微信小程序中如何使用Async-await方法異步請求變?yōu)橥秸埱蠓椒ǖ膬?nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作中從網(wǎng)站色彩、結(jié)構(gòu)布局、欄目設(shè)置、關(guān)鍵詞群組等細(xì)微處著手,突出企業(yè)的產(chǎn)品/服務(wù)/品牌,幫助企業(yè)鎖定精準(zhǔn)用戶,提高在線咨詢和轉(zhuǎn)化,使成都網(wǎng)站營銷成為有效果、有回報(bào)的無錫營銷推廣。創(chuàng)新互聯(lián)建站專業(yè)成都網(wǎng)站建設(shè)十年了,客戶滿意度97.8%,歡迎成都創(chuàng)新互聯(lián)客戶聯(lián)系。

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

注意:

Async-await方法屬于ES7語法,在小程序開發(fā)工具中如果勾選es6轉(zhuǎn)es5, 會報(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.js

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

微信小程序中如何使用Async-await方法異步請求變?yōu)橥秸埱蠓椒?></p><p>同步處理異步請求</p><p>在根目錄下新建api文件夾,里面新建index.js</p><pre>// 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)
  }
 })
 })
}

// 關(guān)閉loading
const hideLoading = () => {
 return new Promise((resolve) => {
 wx.hideLoading()
 console.log('隱藏loading')
 resolve()
 })
}

module.exports = {
 getData,
 postData,
 showLoading,
 hideLoading
}</pre><p>在入口文件 app.js 中引入:</p><pre>//app.js 
const api = require('./api/index')

App({
 onLaunch: function () {
 
 },
 // 全局?jǐn)?shù)據(jù)中暴露api
 globalData: { 
 api
 }
})</pre><p>在需要使用api 的頁面中處理如下:</p><pre>// 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() // 請求數(shù)據(jù)
 await api.hideLoading() // 等待請求數(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)
  })
 })
 },
 
})</pre><p>感謝各位的閱讀!關(guān)于“微信小程序中如何使用Async-await方法異步請求變?yōu)橥秸埱蠓椒ā边@篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!</p>                                                <br>
                                                文章標(biāo)題:微信小程序中如何使用Async-await方法異步請求變?yōu)橥秸埱蠓椒?創(chuàng)新互聯(lián)                                                <br>
                                                文章網(wǎng)址:<a href=http://www.dlmjj.cn/article/ieopi.html