JS的闭合(Closure)

实例
复制代码
function foo() {
let test1 = ‘变量1’
const test2 = ‘变量2’
let test3 = ‘变量3’
var innerBar = {
getName: function () {
console.log(test1)
return test2
},
}
return innerBar
}
var bar = foo()
bar.getName()
复制代码

我们可以通过控制台的Source中的scope看到闭包

image.png

右边 Scope 项就体现出了作用域链的情况:Local 就是当前的 getName 函数的作用域,Closure(foo) 是指 foo 函数的闭包,最下面的 Global 就是指全局作用域,从“Local–>Closure(foo)–>Global”就是一个完整的作用域链。

注意⚠️:只有我们在内部函数中使用的变量才会被加入闭包(Closure)中。

我们来看下范例中产生闭包时执行栈的情况:

当执行到 foo 函数内部的return innerBar这行代码时调用栈的情况
image.png

当 foo 函数执行完成之后,其整个调用栈的状态(注意⚠️:此时foo执行上下文已出栈)
image.png

当执行到bar.getName()时的栈状态
image.png

通过上面三个图我们可以清晰的看到当前作用域链 是Local–>Closure(foo)–>Global。

用途
实现私有变量
复制代码
function Animal( ){

//私有变量
var series = "哺乳动物";
function run( ){
    console.log("Run!!!");
}   

//特权方法
this.getSeries = function(){
    return series;
};

}
复制代码
实现模块模式
复制代码
var Counter = (function() {
var privateCounter = 0;
function changeBy(val) {
privateCounter += val;
}
return {
increment: function() {
changeBy(1);
},
decrement: function() {
changeBy(-1);
},
value: function() {
return privateCounter;
}
}
})();

console.log(Counter.value()); /* logs 0 /
Counter.increment();
Counter.increment();
console.log(Counter.value()); /
logs 2 /
Counter.decrement();
console.log(Counter.value()); /
logs 1 */
深圳网站建设www.sz886.com

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值