为什么在事件处理程序中,`item` 变量的值为 `null`?

为什么在事件处理程序中,`item` 变量的值为 `null`?

为什么在后续代码中,前面函数中的 item 为 null

我们在代码中使用以下函数添加点击事件处理程序:

divs.forEach(item => {  // ...  item.addEventListener('click', () => {    // ...  })  item = null;})

登录后复制

当用户点击某个 div 元素时,事件处理程序将执行 console.log(item),但此时 item 已被设置为 null。许多开发人员可能会假设 console.log(item) 会在点击之前先执行,但事实并非如此。

事件处理程序是异步的

与我们通常编写的同步代码不同,事件处理程序是在主事件循环之外执行的。当代码执行到 item.addEventListener(‘click’, …) 时,它不会立即执行点击事件处理程序。相反,它会在事件队列中注册一个回调函数。

同步代码先执行

在事件队列中的回调函数执行之前,我们设置 item = null 的代码将首先执行,因为它是同步代码。这意味着当事件处理程序最终被触发时,item 已经为 null。

修复方法

要修复此问题,我们可以将 item = null; 代码移到事件处理程序内部。

divs.forEach(item => {  // ...  item.addEventListener('click', () => {    // ...    item = null;  })})

登录后复制

这样,只有在点击事件发生时才设置 item 为 null。

以上就是为什么在事件处理程序中,`item` 变量的值为 `null`?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2808096.html

(0)
上一篇 2025年3月8日 22:38:58
下一篇 2025年3月8日 22:39:10

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论