HTMLElement.click()的回调触发踩坑
先看看以下代码
const el = document.getElementById("btn")
el.addEventListener("click", () => {Promise.resolve().then(() => console.log("microtask 1"));console.log("1");
});
el.addEventListener("click", () => {Promise.resolve().then(() => console.log("microtask 2"));console.log("2");
});
点击按钮后,分别进入两个回调,进入第一个回调时,先加到微任务,然后打印 1。
每个宏任务之间会先清空所有微任务,因此打印顺序是 1- 》 microtask1- 》 2-》 microtask2。
那如果按钮点击不是用户触发,而是代码触发呢?
const el = document.getElementById("btn")
el.addEventListener("click", () => {Promise.resolve().then(() => console.log("microtask 1"));console.log("1");
});
el.addEventListener("click", () => {Promise.resolve().then(() => console.log("microtask 2"));console.log("2");
});
el.click()
按理说输出应该一样才对,但输出竟然变了!

是 click 这个函数有什么特别吗?
问了下 gpt,说是 click 会立即把回调同步执行的,那就符合预期了。


而当按钮是用户点击触发时,回调就分为多个宏任务触发了。

相关文章:
HTMLElement.click()的回调触发踩坑
先看看以下代码 const el document.getElementById("btn") el.addEventListener("click", () > {Promise.resolve().then(() > console.log("microtask 1"));console.log("1"); }); el.addEventListener("click", (…...
mysql锁-这条sql加了哪些锁
文章目录 1、 InnoDB的三种行锁2、常见的加锁语句2.1、常见隐式加锁语句2.1、常见显示加锁语句 3、加锁的2条规则4、案例4.1、唯一索引等值查询4.2、唯一索引范围查询4.3、非唯一索引等值查询4.4、非唯一索引范围查询 InnoDB 存储引擎中的行锁的加锁规则。 1、 InnoDB的三种行锁…...
Docusaurus框架——快速搭建markdown文档站点介绍sora
文章目录 ⭐前言⭐初始化项目💖 创建项目(react-js)💖 运行项目💖 目录文件💖 创建一个jsx页面💖 创建一个md文档💖 创建一个介绍sora的文档 ⭐总结⭐结束 ⭐前言 大家好࿰…...
Prompt 编程的优化技巧
一、为什么要优化 一)上下文限制 目前 GPT-3.5 以及 GPT-4最大支持 16K 上下文,比如你输入超过 16k 的长文本,ChatGPT 会提示文本过大,为了避免 GPT 无法回复,需要限制 上下文在16k 以内 上下文对于 GPT 来说是非常重…...
React PureComponent 和 React.memo()区别
1 注意 ● PureComponent和memo仅作为性能优化的方式存在 ● 不要依赖它来阻止渲染,会产生BUG ● PureComponnet 和memo 都是通过对 props 值的浅比较来决定该组件是否需要更新的。 2 PureComponent 和React.memo() 区别 PureComponent 和React.memo()都是React优化…...
CentOS 7全系列免费
CentOS 7 全系列免费:桌面版、工作站版、服务器版等等………… 上文,关于CentOS 7这句话,被忽略了。 注意版本:知识产权、网络安全。...
【Spring连载】使用Spring Data访问 MongoDB----Aggregation Framework支持
【Spring连载】使用Spring Data访问 MongoDB----聚合框架支持 一、基础槪念二、投影表达式Projection Expressions三、分面分类法Faceted Classification3.1 桶Buckets3.2 多方面的聚合Multi-faceted Aggregation3.3 按计数排序Sort By Count3.4 投影表达式中的Spring表达式支持…...
【深入理解设计模式】适配器设计模式
适配器设计模式 适配器设计模式是一种结构型设计模式,用于将一个类的接口转换成客户端所期望的另一个接口,从而使得原本由于接口不兼容而不能一起工作的类能够一起工作。适配器模式通常用于以下场景: 现有接口与需求不匹配:当需要…...
ASP.NET-实现图形验证码
ASP.NET 实现图形验证码能够增强网站安全性,防止机器人攻击。通过生成随机验证码并将其绘制成图像,用户在输入验证码时增加了人机交互的难度。本文介绍了如何使用 C# 和 ASP.NET 创建一个简单而有效的图形验证码系统,包括生成随机验证码、绘制…...
解决Maven爆红以及解决 Idea 卡在 Resolving问题
关于 Idea 卡在 Resolving(前提是Maven的setting.xml中配置好了阿里云和仓库) 参考文章https://blog.csdn.net/jiangyu1013/article/details/95042611 解决Maven爆红参考文章https://devpress.csdn.net/beijing/656d993b76f0791b6eca7bb0.html?dp_toke…...
MySQL集群 双主架构(配置命令)
CSDN 成就一亿技术人! 今天刚开学第一天给大家分享一期:MySQL集群双主的配置需求和命令 CSDN 成就一亿技术人! 神秘泣男子主页:作者首页 <———— MySQL专栏 :MySQL数据库专栏<———— MySQL双主是一…...
网络安全之安全事件监测
随着人们对技术和智能互联网设备依赖程度的提高,网络安全的重要性也在不断提升。因此,我们需要不断加强网络安全意识和措施,确保网络环境的安全和稳定。 网络安全的重要性包含以下几点: 1、保护数据安全:数据是组织和…...
【BUG 记录】MyBatis-Plus 处理枚举字段和 JSON 字段
【BUG 记录】MyBatis-Plus 处理枚举字段和JSON字段 一、枚举字段(mysql环境已测、postgresql环境已测)1.1 场景1.2 定义枚举常量1.3 配置枚举处理器1.4 测试 二、JSON字段(mysql环境已测)2.1 导包2.2 使用对象接受2.3 测试 三、JS…...
Web性能优化-详细讲解与实用方法-MDN文档学习笔记
Web性能优化 查看更多学习笔记:GitHub:LoveEmiliaForever MDN中文官网 性能优良的网站能够提高访问者留存和用户满意度,减少客户端和服务器之间传输的数据量可降低各方的成本 不同的业务目标和用户需求需要不同的性能度量,要提高…...
组态王连接施耐德M580PLC
组态王连接施耐德M580 网络架构 网线连接PLC和装组态王软件的PC组态设置帮助 可先查看帮助:菜单栏点击【帮助】->【驱动帮助】,在弹出窗口中PLC系列选择莫迪康PLC的“modbusRtu\ASSCII\TCP”查看组态配置流程: 相关说明: 1、…...
pop链构造 [NISACTF 2022]babyserialize
打开题目 题目源代码如下 <?php include "waf.php"; class NISA{public $fun"show_me_flag";public $txw4ever;public function __wakeup(){if($this->fun"show_me_flag"){hint();}}function __call($from,$val){$this->fun$val[0];…...
【VIP专属】Python应用案例——基于Keras, OpenCV和MobileNet口罩佩戴识别
目录 1、导入所需库 2、加载人脸口罩检测数据集 3、对标签进行独热编码...
Doris——荔枝微课统一实时数仓建设实践
目录 一、业务介绍 二、早期架构及痛点 2.1 早期架构 2.2 架构痛点 三、技术选型 四、新的架构及方案 五、搭建经验 5.1 数据建模 5.2 数据开发 5.3 库表设计 5.4 数据管理 5.4.1 监控告警 5.4.2 数据备份与恢复 六、收益总结 七、未来规划 原文大佬这篇Doris腾…...
Stable Diffusion 绘画入门教程(webui)-ControlNet(Inpaint)
上篇文章介绍了语义分割Tile/Blur,这篇文章介绍下Inpaint(重绘) Inpaint类似于图生图的局部重绘,但是Inpain效果要更好一点,和原图融合会更加融洽,下面是案例,可以看下效果(左侧原图…...
LeetCode146: LRU缓存
题目描述 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存 int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则…...
告别电网波动烦恼:手把手教你用双二阶广义积分锁相(DSOGI-PLL)搞定三相PWM整流器
电网谐波抑制实战:基于DSOGI-PLL的三相整流器高精度锁相技术 当你在调试一台三相PWM整流器时,突然发现电网电压出现10%的跌落,设备立即报出"同步失败"故障——这种场景对于电力电子工程师来说再熟悉不过。传统SRF-PLL在理想电网条件…...
告别卡顿!在IMX6ULL上用LVGL 9.0+FFmpeg+OpenCV打造丝滑的本地监控GUI(附源码思路)
告别卡顿!在IMX6ULL上用LVGL 9.0FFmpegOpenCV打造丝滑的本地监控GUI 在嵌入式开发中,流畅的图形界面往往被视为奢侈的需求——尤其是当硬件平台采用像IMX6ULL这样的中低端处理器时。但现实情况是,越来越多的智能设备需要同时处理视频流和复杂…...
别再手动调图了!用MATLAB代码批量美化论文折线图(附完整参数设置清单)
MATLAB科研绘图革命:代码化美学设计全指南 科研图表是论文的"门面",但多数研究者仍被困在重复的手动调整中。我曾耗时两周调整30组实验数据的图表格式,直到发现代码化美学的力量——现在只需5分钟就能完成过去两天的工作量。 1. 为…...
深入浅出聊5G DMRS:从Gold序列到ZC序列,如何为你的上行传输选择最佳参考信号?
5G上行DMRS序列选型实战:从理论特性到工程决策的黄金法则 在5G NR上行调度中,解调参考信号(DMRS)的设计直接影响着信道估计精度和系统性能。面对Type 1(ZC序列)和Type 2(Gold序列)两种DMRS序列选项,以及transform precoding启用/禁用两种模式…...
终极指南:5分钟免费定制Windows UEFI开机画面,告别千篇一律的厂商Logo
终极指南:5分钟免费定制Windows UEFI开机画面,告别千篇一律的厂商Logo 【免费下载链接】HackBGRT Windows boot logo changer for UEFI systems 项目地址: https://gitcode.com/gh_mirrors/ha/HackBGRT 厌倦了每次开机都看到那个一成不变的Window…...
从洗发水销量预测看LSTM过拟合:Keras中Dropout与recurrent_dropout的调参避坑指南
LSTM时间序列预测实战:洗发水销量预测中的Dropout调参艺术 1. 时间序列预测的挑战与LSTM优势 时间序列数据预测一直是机器学习领域最具挑战性的任务之一。与传统的表格数据不同,时间序列数据具有明显的时间依赖性,前后观测值之间存在复杂的非…...
植物大战僵尸终极修改器:PVZ Toolkit完整使用教程
植物大战僵尸终极修改器:PVZ Toolkit完整使用教程 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit 植物大战僵尸PVZ Toolkit是一款专为经典塔防游戏《植物大战僵尸》PC版设计的综合辅助工…...
告别命令行!用Kafka Tool 2.0.4图形化界面管理Topic和消息的保姆级教程
告别命令行!用Kafka Tool 2.0.4图形化界面管理Topic和消息的保姆级教程 你是否曾在深夜对着黑底白字的Kafka命令行界面抓狂?或是面对kafka-topics.sh和kafka-console-consumer.sh的复杂参数感到迷茫?今天,我们将彻底解放你的双手…...
3步掌握Office文档快速预览:高效办公的终极解决方案
3步掌握Office文档快速预览:高效办公的终极解决方案 【免费下载链接】QuickLook.Plugin.OfficeViewer-Native View Word, Excel, and PowerPoint files with MS Office and WPS Office components. 项目地址: https://gitcode.com/gh_mirrors/qu/QuickLook.Plugin…...
空洞骑士模组管理终极指南:Scarab让模组安装变得前所未有的简单
空洞骑士模组管理终极指南:Scarab让模组安装变得前所未有的简单 【免费下载链接】Scarab An installer for Hollow Knight mods written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/sc/Scarab 还在为空洞骑士模组安装的繁琐流程而头疼吗&#x…...
