您的位置:首页 > Web前端 > JavaScript

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 作用域链