JS setTimeout

1.首先,JS是单线程工作,也就是一个脚本执行完毕后才能执行下一个脚本,不能同时执行。

2.JS的一个特点是事件驱动,前端常用的异步方案

任务队列和事件循环是JS引擎管理代码顺序的机制事件循环是有浏览器无限期运行的单线程循环。

每当触发一个事件,浏览器就会将调用的函数加到任务队列进行排队。

任务队列中有多个任务,每个任务一个回调函数,前一个任务结束后,不是执行后一个任务,而是执行回调函数,后一个任务不用等前一个任务结束就执行,所以程序的执行与任务的排列顺序是不一致的,异步的。

  1. 最基础的异步,事件触发才调用函数,而不是根据代码的出现顺序。

使用addEventListner绑定事件

document.getElementById().addEventListner('click'

  1. setTimeout属于js异步任务中的宏任务。宏任务需要等待同步任务,微任务完成后,通过事件轮询触发执行。

在JS 中 setTimeout函数通过将代码放到队列中,并在指定的延迟时间后执行。这个过程是异步的,意味着它不会阻塞主线程的执行,而是在当前代码执行完毕后才开始计时,并在计时完成后将代码放入宏任务队列中等待被主线程读取。

因此setTimeout的代码可能会在串口事件的代码之后执行,具体取决于代码的编写和事件的触发时间。

相关推荐
神探小白牙2 小时前
eCharts 多系列柱状图增加背景图
javascript·ecmascript·echarts
薛定猫AI9 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战
javascript·人工智能·electron
全栈前端老曹9 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口
前端·javascript·百度·dubbo·wgs84·gcj-02·bd09
笑虾9 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率
开发语言·javascript·ecmascript
雾岛听风69110 小时前
JavaScript基础语法速查手册
开发语言·前端·javascript
用户23678298016810 小时前
从零实现 GIF 制作工具:LZW 压缩与 Median Cut 色彩量化
前端·javascript
棉猴10 小时前
Python海龟绘图之绘制文本
javascript·python·html·write·turtle·海龟绘图·输出文本
Highcharts.js11 小时前
线形比赛积分增长或竞赛图|Highcharts企业图表代码示列
开发语言·前端·javascript·折线图·highcharts·竞赛图
让学习成为一种生活方式11 小时前
大肠杆菌合成扑热息痛--对乙酰氨基酚--文献精读227
开发语言·前端·javascript
多秋浮沉度华年11 小时前
electron 初始使用记录
javascript·arcgis·electron