JS setTimeout

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

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

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

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

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

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

使用addEventListner绑定事件

document.getElementById().addEventListner('click'

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

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

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

相关推荐
008爬虫实战录1 小时前
【码上爬】 题十二:如来神掌 困难, JSVMP加密,使用代理补环境
前端·javascript·node.js
threelab2 小时前
Three.js 数学函数着色器 | 三维可视化 / AI 提示词
javascript·人工智能·着色器
ZC跨境爬虫3 小时前
跟着 MDN 学CSS day_3:(为一个传记页面添加样式)
前端·javascript·css·ui·音视频·html5
夜雪闻竹3 小时前
sql.js WASM 实战:浏览器里跑 SQLite
javascript·sql·wasm
爱喝铁观音的谷力景辉3 小时前
在Cesium中实现带箭头方向路线样式的技术详解
javascript·cesium
Qhappy3 小时前
AI逆向实战:从零还原某航空App的AES加密
javascript·后端
安妮的小熊呢4 小时前
CRMEB开源商城系统 & 标准版系统(PHP)开发规范
开发语言·javascript·php
坚定信念,勇往无前5 小时前
electron-vite 安装better-sqlite3
javascript·数据库·electron
@菜菜_达5 小时前
jquery.inputmask插件介绍
前端·javascript·jquery
摸鱼小李上线了5 小时前
vue项目页面添加水印实现方法
前端·javascript·vue.js