0

0

使用 async/await 实现 JavaScript 中的异步加载效果

碧海醫心

碧海醫心

发布时间:2025-10-02 21:22:01

|

681人浏览过

|

来源于php中文网

原创

使用 async/await 实现 javascript 中的异步加载效果

本文将介绍如何使用 async/await 关键字在 JavaScript 中实现异步加载效果,避免 setTimeout 和 setInterval 带来的回调地狱问题。通过创建一个简单的 sleep 函数,结合 async/await,可以使代码看起来更像同步执行,从而提高代码的可读性和可维护性。本文提供了一个完整的示例,模拟了操作系统加载过程,并展示了如何使用 async/await 来控制加载动画的显示和结束。

在 JavaScript 中,处理异步操作的常见方式是使用回调函数、Promise 或 async/await。async/await 提供了一种更简洁、更易于理解的方式来处理异步操作,使代码看起来更像同步代码。

使用 async/await 实现异步加载

下面是一个使用 async/await 实现异步加载的示例,该示例模拟了一个操作系统加载过程,并在控制台中显示加载动画。

首先,定义一个 sleep 函数,该函数返回一个 Promise,该 Promise 在指定的时间后 resolve。

立即学习Java免费学习笔记(深入)”;

皮卡智能
皮卡智能

AI驱动高效视觉设计平台

下载
const sleep = ms => new Promise(r => { setTimeout(r, ms);});

接下来,定义一个 async 函数 OSLoad,该函数模拟操作系统加载过程。该函数使用一个循环来显示加载动画,并在每次循环中使用 await sleep(250) 来暂停 250 毫秒。

async function OSLoad(OS = "", loadingTimeSeconds = 10) {
  var P = ["\", "|", "/", "-"];
  var x = 0;
  for (let lp = 0; lp < loadingTimeSeconds * 4; lp ++) {
    process.stdout.write(
      "
" + P[x++] + " Loading " + OS
    );
    x &= 3;
    await sleep(250);
  }
  process.stdout.write("
" + OS + " is loaded..");
}

最后,调用 OSLoad 函数来启动操作系统加载过程。

OSLoad('Fake OS 4.01');

完整示例代码

下面是完整的示例代码,包括一个简单的控制台模拟器

//very simple console emulator
const pre = document.querySelector('pre');
const consoleBuffer = new Array(10).fill(' ');
let cpos = 0;
const consoleWrite = txt => {
  const s = txt.split('');
  for (const c of s) {
    if (c === '
') cpos = 0;
    else consoleBuffer[cpos++] = c;
  }
  pre.innerText = consoleBuffer.join('');
}
window.process = { stdout: { write: consoleWrite } };


//OS Loader
const sleep = ms => new Promise(r => { setTimeout(r, ms);});

async function OSLoad(OS = "", loadingTimeSeconds = 10) {
  var P = ["\", "|", "/", "-"];
  var x = 0;
  for (let lp = 0; lp < loadingTimeSeconds * 4; lp ++) {
    process.stdout.write(
      "
" + P[x++] + " Loading " + OS
    );
    x &= 3;
    await sleep(250);
  }
  process.stdout.write("
" + OS + " is loaded..");
}


OSLoad('Fake OS 4.01');
pre {
  height: 90vh;
  background-color: black;
  color: white;
}

注意事项

  • async 函数必须使用 await 关键字来等待 Promise resolve。
  • await 关键字只能在 async 函数中使用。
  • 使用 async/await 可以使代码更易于阅读和维护,但也会增加代码的复杂性。

总结

async/await 提供了一种更简洁、更易于理解的方式来处理 JavaScript 中的异步操作。通过创建一个简单的 sleep 函数,结合 async/await,可以使代码看起来更像同步执行,从而提高代码的可读性和可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

339

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

429

2023.10.12

c++ 字符处理
c++ 字符处理

本专题整合了c++字符处理教程、字符串处理函数相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

minimax视频生成教程汇总
minimax视频生成教程汇总

本专题整合了minimax生成视频相关教程,阅读下面的文章了解更多详细操作。

0

2026.03.17

c++ 读取二进制文件
c++ 读取二进制文件

本专题整合了c++读取二进制文件相关内容与教程,阅读专题下面的文章了解更多详细操作。

0

2026.03.17

c++ 全局变量
c++ 全局变量

本专题整合了c++全局变量的使用、定义、作用域等等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

c++ 全局变量
c++ 全局变量

本专题整合了c++全局变量的使用、定义、作用域等等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

11

2026.03.16

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

22

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号