javascript中上下文环境就是this指针,即被调用函数所处的环境。这个上下文环境在大多数情况下指的是函数运行时封装这个函数的那个对象;当不通过任何对象单独调用一个函数时,上下文环境指的就是全局的window对象。

var someuser = {
name:'byvoid',
display:function() {
console.log(this.name);
}
}; someuser.display(); // 输出byvoid var foo = {
bar:someuser.display,
name:'foobar'
}; foo.bar(); //输出foobar

  this指针不属于某个函数,而是函数调用时所属的对象。使用不同的引用来调用同一个函数时,this指针永远是这个引用所属的对象。对象中的嵌套函数的this上下文环境是全局的window对象。这个容易出错,我们可以在this指向包含这个函数的对象时,将this的值保存在一个变量that中,然后用到的时候用这个变量。在使用new关键字创建对象时,this指向的是通过构造函数所创建的那个对象实例。

var apar={
isLocked: false,
lock: function(){
var that=this; //保存指向apar对象的上下文环境的this
this.isLocked=true;
function doSomething(){
alert(this===apar); //false
alert(this===window); //true
alert(that===apar); //true
that.isLocked=false;
}
doSomething();
}
};
05-11 19:43