JavaScript 对闭包的理解?

闭包:是指有权访问另一个函数作用域中变量的函数。
创建闭包的最常见的方式:
就是在一个函数内创建另一个函数,创建的函数可以访问到当前函数的局部变量。
闭包有两个常用的用途:
- 使我们在函数外部能够访问到函数内部的变量。
	通过使用闭包,可以通过在外部调用闭包函数,从而在外部访问到函数内部的变量,可以使用这种办法来创建私有变量。
- 使已经运行结束的函数上下文中的变量对象继续留在内存中。
	因为闭包函数保留了这个变量对象的引用,所以这个变量对象不会被回收。
比如,函数 A 内部有一个函数 B,函数 B 可以访问到函数 A 中的变量,那么函数 B 就是闭包。
function A() {
  let a = 1
  window.B = function () {
	  console.log(a)
  }
}
A()
B() // 1
在 JS 中,闭包存在的意义就是让我们可以间接访问函数内部的变量。经典面试题:循环中使用闭包解决 var 定义函数的问题
for (var i = 1; i <= 5; i++) {
  setTimeout(function timer() {
	console.log(i)
  }, i * 1000)
}

首先因为 setTimeout 是个异步函数,所以会先把循环全部执行完毕,这时候 i 就是 6 了,所以会输出一堆 6。解决办法有三种:

第一种是使用闭包的方式:
for (var i = 1; i <= 5; i++) {
	;(function(j) {
		setTimeout(function timer() {
			console.log(j)
		}, j * 1000)
	})(i)
}

在上述代码中,首先使用了立即执行函数将 i 传入函数内部,这个时候值就被固定在了参数 j 上面不会改变,当下次执行 timer 这个闭包的时候,就可以使用外部函数的变量 j,从而达到目的。

第二种就是使用 setTimeout 的第三个参数,这个参数会被当成 timer 函数的参数传入:
for (var i = 1; i <= 5; i++) {
  setTimeout(
	function timer(j) {
	  console.log(j)
	},
	i * 1000,
	i
  )
}
第三种就是使用 let 定义 i :
for (let i = 1; i <= 5; i++) {
  setTimeout(function timer() {
	console.log(i)
  }, i * 1000)
}
posted @ 2025-08-19 15:57  HECHEN****  阅读(13)  评论(0)    收藏  举报