时间:2021-05-18
微信小程序中有些 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.jsconst regeneratorRuntime = require('../../lib/regenerator-runtime/runtime')同步处理异步请求
在根目录下新建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) } }) })}// 关闭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 () { }, // 全局数据中暴露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() // 请求数据 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) }) }) }, })参考:https://www.jb51.net/article/158645.htm
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近在写微信小程序,为了能用上async/await方法,需要把微信提供的异步操作包装成Promise对象,为此写了一个简单的promise(fie)函数:/*
jquery中ajax方法有个属性async用于控制同步和异步,默认是true,即ajax请求默认是异步请求,有时项目中会用到AJAX同步。这个同步的意思是当J
昨天看了一篇vue的教程,作者用async/await来发送异步请求,从服务端获取数据,代码很简洁,同时async/await已经被标准化,也是需要学习一下了。
在.NETCore中使用异步编程已经很普遍了,你在项目中随处可见async和await,它简化了异步操作,允许开发人员,使用同步的方式编写异步代码,你会发现在大
采用微信组件的方式提供,因组件内部使用了async/await,所以请在微信开发者工具"详情=》本地设置勾上增强编译和使用npm",小程序npm使用方法请参考: