日期:2014-05-16  浏览次数:20391 次

JavaScript中的作用域链和闭包

  • 作用域
    • 全局作用域
    • 局部作用域
  • 作用域链
  • 执行上下文
  • 活动对象
  • 闭包
  • 闭包优化

        JavaScript中出现了一个以前没学过的概念——闭包。何为闭包?从表面理解即封闭的包,与作用域有关。所以,说闭包以前先说说作用域。

作用域(scope)

        通常来说一段程序代码中使用的变量和函数并不总是可用的,限定其可用性的范围即作用域,作用域的使用提高了程序逻辑的局部性,增强程序的可靠性,减少名字冲突。

        全局作用域(Global Scope)

        在代码中任何地方都能访问到的对象拥有全局作用域,以下几种情形拥有全局作用域:

        1、最外层函数和在最外层函数外面定义的变量拥有全局作用域,例如:

2、未定义直接赋值的变量自动声明为拥有全局作用域,例如:

3、所有window对象的属性拥有全局作用域,例如:window对象的内置属性都拥有全局作用域,例如window.name、window.location、window.top等

局部作用域(Local Scope)

作用域链(scope chain)

         JavaScript中,JavaScript里一切都是对象,包括函数。函数对象和其它对象一样,拥有可以通过代码访问的属性和一系列仅供JavaScript引擎访问的内部属性。其中一个内部属性是作用域,包含了函数被创建的作用域中对象的集合,称为函数的作用域链,它决定了哪些数据能被函数访问。
  当一个函数创建后,它的作用域链会被创建此函数的作用域中可访问的数据对象填充。例如函数:

        在函数add创建时,它的作用域链中会填入一个全局对象,该全局对象包含了所有全局变量,如下图所示(注意:图片只例举了全部变量中的一部分):

 

        由此可见,函数的作用域链是创建函数的时候创建的。

执行上下文(Execute context 

        函数add的作用域将会在执行时用到,例如:

        当执行 add 函数的时候, JavaScript 会创建一个 Execute context (执行上下文),执行上下文中就包含了 add 函数运行期所需要的所有信息。