技术文摘
图例剖析 setTimeout 与循环闭包的经典面试题
图例剖析 setTimeout 与循环闭包的经典面试题
在 JavaScript 开发中,setTimeout 与循环闭包相关的问题常常出现在面试场景中,理解它们对于开发者来说至关重要。
让我们来看一个简单的循环示例:
for (var i = 0; i < 5; i++) {
setTimeout(function() {
console.log(i);
}, 1000);
}
在这个例子中,我们期望每隔 1 秒依次输出 0 到 4 。然而,实际的输出结果却是 5 个 5 。这是因为 var 声明的变量作用域是函数级别的,在循环结束后,i 的值已经变成了 5 。
为了解决这个问题,我们可以使用 let 来声明变量。
for (let i = 0; i < 5; i++) {
setTimeout(function() {
console.log(i);
}, 1000);
}
因为 let 声明的变量具有块级作用域,每次循环都会创建一个新的变量 i ,从而得到我们期望的输出结果。
再来看一个更复杂的例子:
function closureExample() {
var arr = [];
for (var i = 0; i < 5; i++) {
arr.push(function() {
console.log(i);
});
}
return arr;
}
var funcs = closureExample();
for (var j = 0; j < funcs.length; j++) {
funcs[j]();
}
这里,当我们执行返回的函数时,输出的依然是 5 。这是因为在函数 closureExample 中创建的匿名函数形成了闭包,它们都引用了外部函数中的变量 i ,而循环结束后 i 的值为 5 。
解决方法是将循环中的函数修改为立即执行函数表达式:
function closureExample() {
var arr = [];
for (var i = 0; i < 5; i++) {
(function(j) {
arr.push(function() {
console.log(j);
});
})(i);
}
return arr;
}
通过这种方式,每个函数都能捕获到当前循环中 i 的值,从而实现正确的输出。
理解 setTimeout 和循环闭包的工作原理对于写出正确、高效的 JavaScript 代码至关重要。在面试中,能够清晰地解释这些概念和解决相关问题,将展示出您扎实的 JavaScript 基础知识和解决复杂问题的能力。
TAGS: 经典面试题 SetTimeout 循环闭包 图例剖析
- 微信扫码登录后怎样自动关闭弹窗并刷新主窗口
- 为何用 标签播放音频资源失败,而用 标签能成功
- CSS与JavaScript实现表格横向排列、点击按钮生成新表格右移且操作按钮位置不变方法
- 用遮罩动画在Vue 3中实现图像轮播效果的方法
- 支持年、季度、月、周、日等多时间范围选择的开源 JS 时间插件有哪些
- 修改DOM元素ID后CSS样式失效的原因
- 为何 a 标签可直接播放音频,audio 标签却不能播放
- Flex布局怎样实现书签的垂直水平均匀分布
- 前端JavaScript中MD5加密数组的使用方法
- PC端多屏适配及PC兼响应式H5项目的实现方法
- CSS 中透明度(opacity)是否影响元素层级顺序
- PC 端多屏适配与 PC 兼响应式 H5 项目的实现方法
- JavaScript 中 void 0 代表什么及如何使用
- Echarts地图鼠标移入显示NaN问题及数据赋值为空解决方法
- 利用CSS Grid布局解决列数不足与元素宽度不一致问题的方法