uniapp _微信小程序使用async,await(易如反掌的理解清楚)

2024-02-22 15:04

本文主要是介绍uniapp _微信小程序使用async,await(易如反掌的理解清楚),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、async,await是什么

asyncawait 是 JavaScript 中处理异步编程的一种方式,它们是 ECMAScript 2017(也被称为 ES8)引入的新特性。

1、async 函数:

async 关键字用于声明一个函数是异步函数。异步函数在执行时返回一个 Promise 对象。它使得在函数内部可以使用 await 关键字等待异步操作的完成。

async function myAsyncFunction() {return 42; // 返回一个 Promise 对象
}

2、await 表达式:

await 关键字只能在 async 函数内部使用。它等待 Promise 对象的解析,并返回 Promise 解析后的值。

async function fetchData() {const result = await someAsyncFunction(); // 等待异步操作完成console.log(result); // 使用异步操作的结果
}

await 将暂停函数的执行,直到 Promise 被解析或拒绝。它可以用于等待异步操作完成,而不阻塞整个线程。

如果不写await会发什么什么?(面试曾经问过)

答案:

如果在 async 函数内部不使用 await 关键字,即不等待异步操作的完成,那么该函数将在异步操作开始后立即返回,并不会等待异步操作的结果。这可能导致意外的行为,因为在异步操作完成之前,函数可能已经执行完毕。

使用 await 和不使用 await 的区别

// 模拟异步操作的函数
function asyncFunction(delay, value) {return new Promise(resolve => {setTimeout(() => {console.log(value);resolve(value);}, delay);});
}// 使用 await 的情况
async function exampleWithAwait() {console.log('Start');await asyncFunction(1000, 'Async Operation 1');await asyncFunction(500, 'Async Operation 2');console.log('End');
}// 不使用 await 的情况
function exampleWithoutAwait() {console.log('Start');asyncFunction(1000, 'Async Operation 1');asyncFunction(500, 'Async Operation 2');console.log('End');
}// 调用两个例子
exampleWithAwait();
exampleWithoutAwait();

exampleWithAwait 中,await 会等待每个异步操作完成后再执行下一个。输出顺序将是:

Start
Async Operation 1  // 等待1秒后输出
Async Operation 2  // 再等待0.5秒后输出
End

而在 exampleWithoutAwait 中,由于没有使用 await,两个异步操作会同时开始执行,不会等待前一个操作完成。输出顺序可能是:

Start
End
Async Operation 2  // 先输出,因为只等待0.5秒
Async Operation 1  // 然后输出,因为等待了1秒

await 只能在 async 函数内部使用。当执行到 await 关键字时,它会暂停函数的执行,等待异步操作完成,然后获取异步操作的结果。一旦异步操作完成,await 后面的代码才会继续执行。这确保了异步操作按照顺序执行,而不是像同步代码一样立即执行。这对于处理异步任务的结果或确保操作的正确顺序非常有用。如果没有 await,则异步操作会在后台执行,而函数会继续执行后续代码,可能导致不确定的结果,如果没有使用 await,则两个异步操作会同时开始执行,而不考虑它们的相对顺序。

二、一般搭配try和catch使用

相当于promise里面的.then和.catch

async function example() {try {const result1 = await asyncFunction1();console.log(result1);const result2 = await asyncFunction2();console.log(result2);} catch (error) {console.error('An error occurred:', error);}
}example();

 如果 asyncFunction1asyncFunction2 中的任何一个出现错误,都会被捕获到 catch 块中,然后输出错误信息。这样可以更好地处理异步操作中的异常情况。async/await 更直观易读

这篇关于uniapp _微信小程序使用async,await(易如反掌的理解清楚)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/735618

相关文章

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

浅析如何使用xstream实现javaBean与xml互转

《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设