浅谈Js闭包

全局变量:全局变量存在于整个程序的运行过程中,随处都可以访问,也就意味着随处都可以修改。

局部变量:只有在当前函数内部才可以访问的变量,别的地方不能访问也不能修改。

什么是闭包?

函数和对其周围状态的引用捆绑在一起构成闭包;也就是说,闭包可以让你从内部函数访问外部函数的作用域,在js中,每当函数被创建,就会在函数生成时生成闭包。

闭包就是由嵌套函数形成的一个词法环境。

有了闭包,我们就可以在一个函数里访问另一个函数的局部变量,这个变量可以重复使用且不会造成全局污染。

例如:

function func () {
    let n = 1;
    function func2() {
        return ++n;
    }
    return func2
}

const funcTest = func()

console.log(funcTest()) // 2
console.log(funcTest()) // 3
console.log(funcTest()) // 4
console.log(funcTest()) // 5

const funcTest2 = func()

console.log(funcTest2()) // 2
console.log(funcTest2()) // 3
console.log(funcTest2()) // 4
console.log(funcTest2()) // 5

以上代码就是一个经典的闭包,一般构成闭包有三步:

1.外层函数嵌套内层函数

2.内层函数使用外层函数的局部变量(或参数)

3.将内层函数作为外层的返回值

 由此可见:

1.在一个函数里访问另一个函数的局部变量,也就是访问另一个作用域

2.变量既可以重复使用,又不会全局渲染(因为别的地方访问不到)

每调用一次外层函数就得到一套闭包,多次调用时多个闭包,不会互相影响 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值