返回顶部
首页 > 资讯 > 前端开发 > node.js >微信小程序中如何使用Async-await方法异步请求变为同步请求方法
  • 810
分享到

微信小程序中如何使用Async-await方法异步请求变为同步请求方法

2024-04-02 19:04:59 810人浏览 安东尼
摘要

这篇文章给大家分享的是有关微信小程序中如何使用Async-await方法异步请求变为同步请求方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。微信小程序中有些 api 是异步的,

这篇文章给大家分享的是有关微信小程序中如何使用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方法异步请求变为同步请求方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: 微信小程序中如何使用Async-await方法异步请求变为同步请求方法

本文链接: https://lsjlt.com/news/77613.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 微信小程序中如何使用Async-await方法异步请求变为同步请求方法
    这篇文章给大家分享的是有关微信小程序中如何使用Async-await方法异步请求变为同步请求方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。微信小程序中有些 Api 是异步的,...
    99+
    2024-04-02
  • Node.js中Express框架使用axios同步请求(async+await)实现方法
    axios一般是作为异步请求使用的,但是某种特殊情况下需要同步请求,如何实现呢? 首先定义一个方法syncAxios let axios = require('axios'); e...
    99+
    2023-05-15
    Node.js Express axios 同步请求 async await
  • 微信小程序如何同步请求授权
    这篇文章主要为大家展示了“微信小程序如何同步请求授权”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“微信小程序如何同步请求授权”这篇文章吧。微信小程序 同步请求授...
    99+
    2024-04-02
  • 微信小程序中es6-promise.js封装请求与处理异步进程的方法
    这篇文章主要介绍“微信小程序中es6-promise.js封装请求与处理异步进程的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“微信小程序中es6-promise.js封装请求与处理异步进程的方...
    99+
    2023-06-17
  • 微信小程序开发中如何封装HTTP请求方法
    这篇文章主要介绍微信小程序开发中如何封装HTTP请求方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!HTTP请求方法的封装在小程序中http请求是很频繁的,但每次都打出wx.req...
    99+
    2024-04-02
  • 微信小程序中如何使用es6-promise.js封装请求与处理异步进程
    这篇文章主要介绍微信小程序中如何使用es6-promise.js封装请求与处理异步进程,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!微信小程序 es6-promise.js封装请求与...
    99+
    2024-04-02
  • 微信小程序请求前置的方法详解
    问题 因为我们有的页面是在onload中去请求数据回来再渲染视图,如果我们可以将请求数据这一步提前到小程序页面跳转前做,就可以早一点把数据请求回来,优化的效果取决于页面跳转所需的时...
    99+
    2024-04-02
  • ASP应用程序中如何处理异步请求?
    随着互联网技术的不断发展,越来越多的网站需要处理大量的异步请求,以提高网站的性能和用户体验。ASP应用程序也不例外,如何处理异步请求是一个非常重要的问题。本文将介绍ASP应用程序中如何处理异步请求,希望能对ASP开发者有所帮助。 一、什么...
    99+
    2023-07-27
    缓存 shell 异步编程
  • 微信小程序怎么使用es6-promise.js封装请求与处理异步进程
    这篇“微信小程序怎么使用es6-promise.js封装请求与处理异步进程”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“微信...
    99+
    2023-06-17
  • Java 异步编程中,如何使用 Path 响应请求?
    随着网络技术的不断发展,Web 应用程序的性能要求越来越高。为了提高 Web 应用程序的性能,我们需要使用异步编程技术。Java 语言提供了多种异步编程技术,其中最常用的是 Path。Path 是 Java NIO 中的一个类,可以在异步...
    99+
    2023-10-31
    异步编程 响应 path
  • Java 异步编程教程:如何在http请求中使用多线程实现异步编程?
    Java是一种面向对象的编程语言,具有很好的可移植性和可扩展性,在Web开发中广泛应用。然而,由于Web应用程序需要处理大量的http请求,因此必须采用异步编程技术,以确保Web应用程序的性能和可扩展性。 在本文中,我们将介绍如何使用Ja...
    99+
    2023-06-25
    异步编程 教程 http
  • 如何在ASP应用程序中使用异步编程模型来处理并发请求?
    在ASP应用程序中处理并发请求是一个很常见的场景,但是当并发请求量增加时,应用程序可能会变得非常缓慢,甚至崩溃。这时,异步编程模型就成为了解决这个问题的一种方法。 异步编程模型是一种在应用程序中处理并发请求的方法。它可以让应用程序在处理一个...
    99+
    2023-08-04
    存储 异步编程 npm
  • vue中如何使用axios数据请求get、post方法
    小编给大家分享一下vue中如何使用axios数据请求get、post方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!vue中使用axios方法我们先安装axios这个方法npm inst...
    99+
    2024-04-02
  • 微信小程序中如何使用Promise进行异步操作
    这篇文章主要介绍微信小程序中如何使用Promise进行异步操作,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!微信小程序中使用Promise进行异步流程处理我们知道,JavaScrip...
    99+
    2024-04-02
  • 如何在微信小程序中使用Echarts方法
    如何在微信小程序中使用Echarts方法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。xxx.json{ "usingComponents":...
    99+
    2023-06-08
  • 微信小程序中如何调用scale方法
    这篇文章主要介绍“微信小程序中如何调用scale方法”,在日常操作中,相信很多人在微信小程序中如何调用scale方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序中如何调用scale方法”的疑惑有所...
    99+
    2023-06-26
  • 微信小程序使用webview打开pdf文档以及显示网页内容的方法步骤
    目录一、微信小程序根据接口返回的pdf链接,在小程序内部浏览pdf内容二、根据网页链接,把网页内容在微信小程序内部显示总结一、微信小程序根据接口返回的pdf链接,在小程序内部浏览pd...
    99+
    2024-04-02
  • C#中如何使用异步编程模型和并发编程处理任务分发及解决方法
    C#中如何使用异步编程模型和并发编程处理任务分发及解决方法引言:在现代的软件开发中,我们经常面临处理大量任务的情况,而这些任务可能是独立的,互不干扰的。为了提高程序的性能和效率,我们希望能够并发地处理这些任务,并且在每个任务完成时能够得到相...
    99+
    2023-10-22
    并发编程 异步编程 任务分发
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作