JavaScript闭包

闭包是有权访问另外一个函数作用域中变量的函数


在了解闭包之前,需要先了解几个概念,具体如下:

当某个环境被调用的时候,会创建一个执行环境以及相应的作用域链。然后,使用arguments和其他命名参数的值来初始化函数的活动对象。但在作用域链中,外部函数的活动对象始终在第二位,外部函数的外部函数,排在了第三位,以此类推,排外最尾部的是全局执行环境。


执行环境

执行环境(execution context)又称为执行上下文,有时直接称之为环境,是JavaScript中一个很重要的概念。通过它可以判断变量或者函数是否有权访问其他数据。每个执行环境都有一个变量对象(variable object)这个对象中包含了在这个环境中定义的所有的变量和函数。全局执行环境是最底层的执行环境。在web浏览器中,全局执行环境被认为是window对象,因此所有的全局变量和函数都是作为window对象的属性和方法创建的。当某个执行环境里面的代码全部执行完毕的时候,该环境就会被销毁,包括该环境中的所有变量,定义的函数也会随之销毁。而全局执行环境是一直到关闭浏览器才会被销毁。

每个函数都有自己的执行环境,当执行流进入这个函数的时候,函数的环境就会被推入一个环境栈中,当函数执行完毕后,栈将其环境弹出。


作用域链

当代码在环境中执行时,会创建变量对象的一个作用域链。作用域链的作用是保证对执行环境有权访问的所有变量和函数的有序访问。他的本质上是一个指向变量对象的指针列表。其第一个节点里有当前环境的变量对象(如果环境是函数,这把活动对象(一开始为arguments)作为变量对象)。第二个节点为其环境的下一个包含环境的变量对象以此类推,一直到全局执行环境包含的变量对象(全局环境没有arguments)。

寻找某一个变量或者函数时,都是沿着作用域链开始层层往后搜索,一直到找到为止,如果找不到,则返回undefined。


闭包

闭包的概念其实并不复杂,就是有权访问另外一个函数作用域中变量的函数通常的创建方式为一个函数内部创建另一个函数。

当然,还有一种更广泛的理解,只要是内部函数以值传递的形式,或者当做参数,传递给外部函数,那么就发生了闭包


PS

1.闭包中内部函数取得外部函数的变量永远是最后一个值。

2.闭包中,内部函数永远无法取到外部函数的thisarguments,只能取到活动对象。

你可能感兴趣的:(JavaScript闭包)