话说,还是在继续学习js中【js很博大精深吖- -】
上篇转载了一篇“梦想天空“的文章,也是讲解作用域链的,但是还是给出本篇,也算是自己的学习和巩固。
function compare(value1,value2){
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0;
}
}
var result = compare(5,10);
当调用compare时,会创建一个包含arguments,value1和value2的活动对象。全局执行环境的变量对象【包含result和compare】在compare()执行环境的作用域链中则处于第二位。如图:
后台的每个执行环境都有一个表示变量的对象——变量对象。全局环境的变量对象始终存在,而像compare()函数这样的局部环境的变量对象,则只在函数执行过程中存在。在创建compare()函数时,会创建一个预先包含全局变量对象的作用域链,这个作用域链被保存在内部的[[scope]]属性中,当调用compare()函数时,会为函数创建一个执行环境,然后通过复制函数的[[scope]]属性中的对象构建起执行环境的作用域链。此后,又有一个活动对象(在此作为变量对象使用)被创建并别推入执行环境作用域链的前端。对于这个例子中compare()函数的执行环境而言,其作用域链中包含两个变量对象:本地活动对象和全局变量对象。显然,作用域链本质上是一个指向变量对象的指针列表,它只引用但不实际包含对象。
无论什么时候在函数中访问一个变量时,就会从 作用域链中搜索具有相应名字的变量。一般来讲,当函数执行完毕后,局部活动对象就会被销毁,内存中仅保存全局作用域(全局执行环境的变量对象)。但是闭包的情况和此不同。
在另一个函数中定义的函数会将包含函数【即外部函数】的活动对象添加到它的作用域链中。
function createComparisonFunction(property){
return function(obj1,obj2){
var value1 = obj1[property];
var value2 = obj2[property];
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0;
}
}
}
var compare = createComparisonFunction("name");
var result = compare({name:'Nicholas'},{name:'Greg'});
那么呢,其产生的作用域链间关系如下图: