JS与java在this关键字上的处理是不同的,Java可以很清晰的明白this指代的是哪个对象,而js则会产生很多歧义,接下来,我们一步一步解释JS中不同函数或闭包里面的this关键字。
普遍的函数调用: 最后一行代码是完整的调用写法,可以轻易看出调用者为window,所以方法里面的this指代window
function testThis1(){ console.info("Test1="+this);}testThis1();// 简单的写法window.testThis1();//完整的写法嵌套函数调用: 外部函数将返回嵌套函数fn,此时并没有直接调用fn,而是在最外层才调用,所以结果也同上,是由window调用fn,fn里面的this为window
function testThis2(){ var fn = function(){ console.info("Test2="+this); } return fn;}var temp = testThis2();// 将一个函数赋值给变量temptemp();// 正式调用函数window.temp();// 完整写法对象的函数调用: 将函数赋值给对象的属性,作为对象的方法调用,此时调用应该是obj1.action(),明显的看出调用者变为了obj1,又由于所有全局变量都是window的属性,所以可以像最后一行那样调用函数,打印的this结果都是obj1
var obj1 = { action:function(){ console.info("Test3="+this); }};obj1.action();// 对象函数调用window.obj1.action();// 完整写法调用对象函数返回的函数: 当对象函数里面返回函数时,实际上并没有立即调用这个函数,而是返回到最外层进行调用,所以这个嵌套函数的调用者仍然是window,但是对象函数调用者为obj2。也就是说action()里面this指代obj2,匿名嵌套函数this指代window
var obj2 = { action:function(){ console.info(this);// 打印obj2 var that = this;// 通常可以缓存this也就是obj2,然后内层函数就可以直接用that,而不是使用this了 return function(){ console.info(that);// 打印obj2 console.info(this);// 打印window }; }}obj2.action();// 返回一个函数,但此时没有调用该函数obj2.action()();// 正式调用函数,该代码最后的效果应该类似于下面的代码(function(){console.info(this);})();新闻热点
疑难解答