内部函数访问外部函数的变量,采用的是链式查找的方式来决定去哪个值,这种情况我们称为作用域链。(取值遵循就近原则)
var num = 10;
function fn() {
var num = 20;
function fun() {
console.log(num);//输出20;按照链式查找的方式决定去哪个值,就近原则
}
}
作用: 保证对执行环境有权访问的所有变量和函数的有序访问。
如何构建作用域链:
答:某个函数被调用的时候,就会创建一个执行环境及相应的作用域链,使用argume和其他命名参数的值来初始化函数的活动对象,在作用域链中,外部函数的活动对象在第二位,外部函数的外部函数的作用对象在第三位....直至作为作用域链终点的全局执行环境。 在函数执行过程中,为读取和写入变量的值,就需要在作用域链中查找变量。而函数内部定义的函数会将外部函数的活动对象添加到他的作用域链中。
如何延长作用域链
(1)try-catch语句的catch块:会创建一个新的变量对象,其中包含的是被抛出的错误对象的声明
(2)with语句:会将指定的对象添加到作用域链中
function buildUrl(){
var qs = "?debug = true";
with(location){
var url = href + qs;
}
return url;
}