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

2024-10-30 10:34:18 编辑:抖狐科技 来源:摘自互联网

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

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

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

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

登录后复制

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

事件处理程序是异步的

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

同步代码先执行

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

修复方法

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

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

登录后复制

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

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

本站文章均为抖狐网站建设摘自权威资料,书籍,或网络原创文章,如有版权纠纷或者违规问题,请即刻联系我们删除,我们欢迎您分享,引用和转载,我们谢绝直接复制和抄袭!感谢...