共计 532 个字符,预计需要花费 2 分钟才能阅读完成。
概述
闭包就是指有权拜访另一个函数作用域中的变量的函数
概念
机制
以后函数执行,会造成一个公有的上下文,函数执行完后,以后执行上下文中的某些内容,被以后上下文以外的内容所占用,那么以后上下文就不能被开释。
思路
- 函数执行 -> 造成公有上下文环境。
- 函数执行实现 -> 以后执行上下文环境中的某些内容,被以后执行上下文外的内容所援用。
- 以后执行上下文不能被开释 -> 以后执行上下文中的变量就不会销毁开释。
例子
const a = 4;
function f(a) {
let variate = 4;
const c = function () {
// 2. 函数 f 执行实现,执行函数 f 时造成公有的上下文环境中的变量 variate 被函数 c 中的内容所援用
// 每次调用 result() 都会从 函数 f 的执行上下文中寻找变量 variate 来援用
variate++;
console.log(variate + a);
}
return c;
}
// 1. 执行函数 f,会造成 f 公有的上下文环境
const result = f(a);
// 3. 函数 f 并没用被开释,变量 variate 也就没用被销毁,而是还存在
// 每次运行 result() 应用的 variate 会递增
result(); // 9
result(); // 10
result(); // 11
result(); // 12
正文完
发表至: javascript
2022-06-19