重点:在js中所有的代码都有其上下文环境,从面向对象的角度来说,就是一个对象必然是一个更大的对象的一部分。而你创建的这个对象,拥有它的外部对象会被他使用,以this指针的形式。但是现在有个问题,当方法从一个对象传递到另外一个对象的时候,它的外部环境发生改变,导致this会在运行时发生改变。正是因为this指针会被改变,所以需要用一个缓存的机制,来存储当前确定的这个this值。
if(!Function.prototype.bind){
Function.prototype.bind = function(obj){
var self = this;
return function(){
return self.apply(obj);
}
};
}
var self = this; 把this的内容保存起来,这样this的值就是定义的时候的上下文环境。
一般函数里面嵌套函数的时候,会用到这种方式,以免this指定的上下文错误。