为什么在事件处理程序中,`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`?的详细内容,更多请关注其它相关文章!