0

0

javascript异步是什么_回调函数和promise有何区别?

夢幻星辰

夢幻星辰

发布时间:2026-01-08 15:17:04

|

535人浏览过

|

来源于php中文网

原创

JavaScript异步解决单线程阻塞导致页面卡死的问题,通过事件循环让耗时操作不占用主线程,保障UI流畅响应;它不提速但防停滞,核心是“别停”而非“快”。

javascript异步是什么_回调函数和promise有何区别?

JavaScript异步到底在解决什么问题?

JavaScript 是单线程的,主线程一旦被阻塞,页面就卡住、无法响应点击或滚动。所谓“异步”,就是让耗时操作(比如 fetch()setTimeout()fs.readFile())不占着主线程等结果,而是先让出控制权,等它做完再通知你——这样页面才不卡。

关键不是“慢”,而是“别停”。异步机制本身不提速,但能保流畅。

  • 常见错误现象:写了个 while (true) 或同步读大文件,整个页面冻结,连开发者工具都打不开
  • 真实场景:用户点按钮后发请求,你不该让按钮一直“按下去”状态不动,而应立刻反馈“加载中”,再等数据回来更新 UI
  • 注意:异步 ≠ 多线程。JS 仍只有一条主线程,靠浏览器/Node.js 的事件循环(Event Loop)调度回调和 Promise 微任务

回调函数为什么容易失控?

回调函数是“你告诉我做完后干啥”,把处理逻辑直接塞进参数里。它简单、兼容性好,但一串起来就暴露三个硬伤:

getUser(id, function(user) {
  getPosts(user.id, function(posts) {
    getComments(posts[0].id, function(comments) {
      console.log(comments);
    });
  });
});
  • 嵌套即地狱:每多一层异步,缩进+1,逻辑向右滑出屏幕,改一处要数括号
  • 错误处理分散:每个回调都得写 if (err) { ... },漏一个就静默失败
  • 无法用 try/catch:异步回调执行时已脱离原始调用try/catch 捕不到
  • 控制流难复用:想“并发发起 3 个请求,全部成功才继续”,得手动计数 + 判断,极易出错

Promise 是怎么把异步“状态化”的?

Promise 不是回调的语法糖,而是把异步操作包装成一个有明确状态的对象:pendingfulfilledrejected,且状态不可逆。你不再告诉它“做完干啥”,而是问它“结果是什么”,然后声明式地响应。

触站AI
触站AI

专业的中文版AI绘画生成平台

下载

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

getUser(id)
  .then(user => getPosts(user.id))
  .then(posts => getComments(posts[0].id))
  .then(comments => console.log(comments))
  .catch(err => console.error('出错了:', err));
  • 链式调用扁平化:每个 .then() 返回新 Promise,天然避免嵌套
  • 错误自动冒泡:任意 .then() 中抛错、或返回被 reject 的 Promise,都会被后续最近的 .catch() 捕获
  • 组合能力开箱即用Promise.all([p1, p2]) 等全部完成;Promise.race([p1, p2]) 取最快那个;Promise.allSettled() 管它成不成,全等完再说
  • 注意:Promise 本身不可取消、没有进度回调、pending 状态无法感知是否卡住——这些是它没解决、也不该解决的问题

什么时候该用回调,什么时候必须转 Promise?

不是谁淘汰谁,而是看接口契约和维护成本:

  • 老 API(如 Node.js 的 fs.readFile(path, callback))仍只接受回调 → 用 util.promisify() 包一层,或手写 new Promise(...) 封装,别裸写回调链
  • 事件监听(button.addEventListener('click', handler))本质是事件机制,不是“异步操作问题”,继续用回调更自然
  • 新项目、封装层、业务逻辑中,一律返回 Promise —— 即使底层用回调,对外也该提供 .then() 接口
  • 绝对避免混合:一个函数既接收 callback 参数,又返回 Promise,调用方会懵,资源可能泄漏

最常被忽略的一点:Promise 构造器里的执行器函数(new Promise((resolve, reject) => {...}))是**同步立即执行**的,里面写错 throw 会直接崩,不是异步错误——这点和 .then() 里的 throw 行为完全不同。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.25

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1946

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

658

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2401

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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