关于this对象,它是基于当前运行环境所绑定的
var name="The Window"; var object={ name:"The Object", getName:function(){ console.log(this.name); //The Object return function(){ return this.name; } } } console.log(object.getName()()); //The Window每个函数在被调用时都会自动取得两个特殊变量——this和arguments。内部函数在搜索这两个变量时,只会搜索到其活动对象位置,因此永远不能直接访问外部函数中的这两个变量,但是可以吧外部作用域中的this对象先保存在一个闭包可以访问的变量中,就可以通过闭包访问之前保存的this作用域。
var name="The Window"; var object={ name:"The Object", getName:function(){ var that=this;//将当前作用域this保存在that变量中 return function(){ return that.name; } } } console.log(object.getName()());//The Object其实我搞不懂为什么js红宝书要这样设计?以下代码不就可以访问了吗
var name="The Window"; var object={ name:"The Object", getName:function(){ return this.name; } } console.log(object.getName());//The Object当函数作为对象里的方法被调用时,函数内的this是调用该函数的对象。比如当object.getName()被调用时,函数内的 this 将绑定到object对象。
所以再嵌套一层匿名函数就是将this的指向指回window,以此演示可以在此之前将this转存的作用。