什么是javascript异步编程_回调函数如何工作?

admin 百科 14
JavaScript异步编程本质是避免耗时操作阻塞主线程,通过回调函数实现非阻塞执行;因JS单线程特性,同步等待会导致页面卡死,异步借助事件循环将回调加入任务队列待调用栈空时执行。

什么是javascript异步编程_回调函数如何工作?-第1张图片-佛山资讯网

JavaScript异步编程,本质是让耗时操作(比如网络请求、定时器、文件读取)不卡住主线程,其他代码能照常运行。回调函数就是实现这一点最基础的方式——它是一个被传进去、等事情做完再执行的函数。

回调函数怎么传、怎么被调用

函数在 JavaScript 里是一等公民,可以像数字或字符串一样当参数传。一个函数(比如 fetchData)内部启动异步任务(如 setTimeout),等任务完成,就主动调用你传进来的那个函数(比如 processData),把结果作为参数交过去。

  • 你写 fetchData(processData),不是立刻执行 processData
  • fetchData 立即返回,继续跑后面代码(比如 console.log('last line')
  • 1 秒后,setTimeout 触发,fetchData 内部才调用 processData(data)

为什么需要异步?单线程不能等

JS 是单线程,同一时间只能干一件事。如果所有操作都同步(比如等服务器回数据再往下走),页面就会完全卡死,按钮点不动、动画停摆、用户没法操作。

  • 同步:代码从上到下一行行执行,前一行没完,后一行不动
  • 异步:发起请求后立即“放手”,继续执行后面的同步代码;结果回来时,再通过回调“插队”处理
  • 背后靠的是事件循环(Event Loop):异步任务完成后,回调被放进任务队列,等调用栈空了,再一个个拉出来执行

回调函数的两种典型用法

一类是通用异步工具,比如 setTimeoutXMLHttpRequest 的老式写法;另一类是业务逻辑中自己封装的异步流程,比如连续请求多个接口。

标签: javascript java js node.js node 回调函数 工具 ai 异步任务 为什么

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~