Javascript作用域链
2017-01-05 21:16
309 查看
Javascript作用域链
先介绍执行环境
* 执行环境定义了变量或函数有权访问的其他数据,决定了它们各自的行为,每个执行环境都有一个与之关联的变量对象,该变量对象里面保存环境中定义的所有变量和函数,每个函数都有自己的执行环境。 *定义:
作用域链:当代码在一个环境中执行时,会创建变量对象的一个作用域链作用:
作用域链:保证对执行环境有权访问的所有变量和函数的有序访问。作用域链的前端,始终都是当前执行的代码所在环境的变量对象作用域链
“`var glo = ‘global’;
function local() {
var loc = ‘local’;
function tem() { var tem = 'tempory'; foo = glo; far = loc; // 这里可访问glo、loc、tem } // 这里可以访问glo、loc,不能访问tem
}
// 这里只能访问glo
“`
* 上例中:代码分为三个执行环境:全局环境、local()局部环境、tem()局部环境,某一个执行环境可以访问上一级执行环境里的变量和函数,不能访问下一级执行环境里的变量和函数,上例中的作用域链为 window–>{glo、local() –> {loc、tem() –> {tem、foo、far}}}**
因此作用域链实际上是一条访问变量和函数的权限规定
相关文章推荐
- JavaScript 开发进阶:理解 JavaScript 作用域和作用域链
- 进击JavaScript之词法作用域与作用域链
- JavaScript:执行环境及作用域链
- 深入理解javascript(14):自由变量到作用域链
- JavaScript-----作用域链
- JavaScript 开发进阶:理解 JavaScript 作用域和作用域链
- JavaScript作用域和作用域链
- javascript笔记:javascript的关键所在---作用域链
- JavaScript 开发进阶:理解 JavaScript 作用域和作用域链
- JavaScript的函数作用域与作用域链详解
- JavaScript 作用域和作用域链 解析
- JavaScript的作用域与作用域链
- javascript中的函数,调用对象,作用域链
- javascript之作用域链
- 个人理解的javascript作用域链与闭包
- javascript之作用域链
- javascript基础进阶_深入剖析执行环境及作用域链
- javascript进阶系列专题:作用域与作用域链
- 深入理解 JavaScript 作用域和作用域链
- JavaScript作用域问题:预解析、全局与局部作用域解析、作用域链