js闭包

var locar = '变量';

function foo(){

  console.log(locar);

}

上面三行代码在一个立即执行函数中。

三行代码中,有一个局部变量 local,有一个函数 foo,foo 里面可以访问到 local 变量。

好了这就是一个闭包:

「函数」和「函数内部能访问到的变量」(也叫环境)的总和,就是一个闭包。

function foo(){
  var local = 1
  function bar(){
    local++
    return local
  }
  return bar
}

var func = foo()
func()

闭包的作用

闭包常常用来「间接访问一个变量」。换句话说,「隐藏一个变量」。

假设我们在做一个游戏,在写其中关于「还剩几条命」的代码。

如果不用闭包,你可以直接用一个全局变量:

window.lives = 30 // 还有三十条命

这样看起来很不妥。万一不小心把这个值改成 -1 了怎么办。所以我们不能让别人「直接访问」这个变量。怎么办呢?

用局部变量。

但是用局部变量别人又访问不到,怎么办呢?

暴露一个访问器(函数),让别人可以「间接访问」。

 

它的最大用处有两个,一个是它可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

 (把一个函数内的局部变量,暴露给外部使用。避免全局全量的声明,隐藏一个变量)

 

 

优点:

① 减少全局变量;

② 减少传递函数的参数量;

③ 封装;

 

 

转:https://zhuanlan.zhihu.com/p/22486908

转:https://zhuanlan.zhihu.com/p/129022735

 

 

posted @ 2020-09-08 10:35  炽橙子  阅读(183)  评论(0编辑  收藏  举报