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

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

 更新時(shí)間:2019年03月28日 15:10:30   作者:Mr.曹  
這篇文章主要介紹了微信小程序中使用Async-await方法異步請(qǐng)求變?yōu)橥秸?qǐng)求方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

微信小程序中有些 Api 是異步的,無法直接進(jìn)行同步處理。例如:wx.request、wx.showToastwx.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.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 的頁面中處理如下:

// 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)
  })
 })
 },
 
})

參考:http://www.dbjr.com.cn/article/158645.htm

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

相關(guān)文章

  • javascript閉包的理解和實(shí)例

    javascript閉包的理解和實(shí)例

    所謂閉包,值得是詞法表示包括不必要計(jì)算的變量的函數(shù),也就是說,該函數(shù)可以使用函數(shù)外定義的變量。
    2010-08-08
  • 微信小程序?qū)崿F(xiàn)一張或多張圖片上傳(云開發(fā))

    微信小程序?qū)崿F(xiàn)一張或多張圖片上傳(云開發(fā))

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)一張或多張圖片上傳,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JavaScript庫 開發(fā)規(guī)則

    JavaScript庫 開發(fā)規(guī)則

    1. 保持無侵入性,標(biāo)記不想知道你的JavaScript代碼;2. 嚴(yán)禁修改和擴(kuò)展Object.prototype!;3. 對(duì)JavaScript內(nèi)建對(duì)象的擴(kuò)展越少越好;4. 跟隨標(biāo)準(zhǔn);5. 或著跟隨主導(dǎo) ;6. 保持靈活;7. 管理內(nèi)存;8. 淘汰瀏覽器嗅探;9. 小巧更佳……
    2009-01-01
  • js實(shí)現(xiàn)右鍵菜單欄功能

    js實(shí)現(xiàn)右鍵菜單欄功能

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)右鍵菜單欄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 深入理解JavaScript系列(35):設(shè)計(jì)模式之迭代器模式詳解

    深入理解JavaScript系列(35):設(shè)計(jì)模式之迭代器模式詳解

    這篇文章主要介紹了深入理解JavaScript系列(35):設(shè)計(jì)模式之迭代器模式詳解,迭代器模式(Iterator):提供一種方法順序一個(gè)聚合對(duì)象中各個(gè)元素,而又不暴露該對(duì)象內(nèi)部表示,需要的朋友可以參考下
    2015-03-03
  • JS+html5制作簡(jiǎn)單音樂播放器

    JS+html5制作簡(jiǎn)單音樂播放器

    這篇文章主要為大家詳細(xì)介紹了JS html5制作簡(jiǎn)單音樂播放器的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JavaScript實(shí)現(xiàn)選中文字提示新浪微博分享效果

    JavaScript實(shí)現(xiàn)選中文字提示新浪微博分享效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)選中文字提示新浪微博分享效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • JS 數(shù)組隨機(jī)洗牌的實(shí)例代碼

    JS 數(shù)組隨機(jī)洗牌的實(shí)例代碼

    這篇文章主要介紹了js 數(shù)組隨機(jī)洗牌的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2018-09-09
  • JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能

    JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能

    FileReader 對(duì)象允許Web應(yīng)用程序異步讀取存儲(chǔ)在用戶計(jì)算機(jī)上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對(duì)象指定要讀取的文件或數(shù)據(jù)。下面通過本文給大家介紹JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能,需要的朋友參考下
    2018-03-03
  • 微信小程序input框中加入小圖標(biāo)的實(shí)現(xiàn)方法

    微信小程序input框中加入小圖標(biāo)的實(shí)現(xiàn)方法

    這篇文章主要介紹了微信小程序input框中加入小圖標(biāo)的實(shí)現(xiàn)方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-06-06

最新評(píng)論