ztree 后台异步加载_JavaScript 中的异步操作

本文详细介绍了JavaScript的异步执行机制,包括同步任务、异步任务(宏任务与微任务)、事件循环(Event Loop)的概念,并重点讲解了Promise和async/await的使用,阐述了它们在解决回调地狱和错误处理上的优势,以及存在的局限性。通过实例解析,帮助读者理解异步编程在JavaScript中的应用。
摘要由CSDN通过智能技术生成

JavaScript 是单线程的(single threaded)

单线程模型指的是,JavaScript 只在一个线程上运行。事实上,JavaScript 引擎有多个线程,但是单个脚本只能在一个线程上运行(称为主线程),其他线程都是在后台配合。

单线程模式的优点是实现起来比较简单,执行环境相对单纯;缺点是耗时长的任务会阻塞其后面任务的执行。为了解决这个缺点,JavaScript 中引入了异步任务。

同步任务和异步任务:

  • 同步任务:那些没有被引擎挂起、在主线程上排队执行的任务。只有前一个任务执行完毕,才能执行后一个任务。同步任务会阻塞代码执行
  • 异步任务:那些被引擎放在一边,不进入主线程、而进入任务队列的任务。当某个异步任务可以执行后,该任务进入主线程执行。异步任务不会阻塞代码执行

异步任务可以分为宏任务和微任务:

  • 宏任务:由浏览器规定的,包括 setTimeout、setInterval、Ajax、DOM 事件等 Web APIs,回调函数放在 Main Task Queue 中
  • 微任务:ES6 语法规定的,包括 Promise、async/await,回调函数放在 Microtask Queue 中

JavaScript 执行时的简易图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值