一个关于this问题

window.val = 1;var obj={val: 2,
dbl: function () {this.val *= 2;val *= 2;
console. log('val:', val) ;
console. log( 'this.val:', this.val) ;

}
};//说出下面的输出结果obj.dbl();var func = obj.dbl;
func();

这个问题我知道放在console中运行去答案,想要的分析this指向问题。


繁星coding
浏览 605回答 3
3回答

UYOU

var func = obj.dbl; func();第一句把函数引用赋值给一个变量,会造成 this 丢失,所以 func 内部的 this 是指向全局对象的。所以函数内部 this.val => window.val => val => 1 。这三个是相等的。所以结果是:this.val = this.val * 2 => 2val = val * 2 => 4val: 4this.val: 4

繁花如伊

考虑了很久,执行obj.dbl()时,this.val 的 this 指向 obj ,而下一行的 val 指向 window。所以,由 window.val 输出 2,obj.val 输出4,最后一行func(); 的调用者是 window, 所以,现在的 this.val 的 this 指向 window,刚刚window.val已经是2了,所以现在this.val = 2;的执行结果就是4,然后val=2;的执行结果,就是8了。所以,最终的结果就是输出2、4、8、8

哈士奇WWW

var func = obj.dbl; 这一步已近改变了this指向全局当执行func();的时候this.val = 2;val = 2;都是对全局变量的修改 默认全局为1 相当于122 然后console. log('val:', val) ;console. log( 'this.val:', this.val) ;都是打印修改后的全局变量而已func();执行一次1 乘以 2 乘以 2 执行两次1 乘以 2 乘以 2 乘以 2 乘以 2
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript