为了账号安全,请及时绑定邮箱和手机立即绑定

一个关于this问题

一个关于this问题

繁星coding 2019-02-27 17:36:00
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指向问题。
查看完整描述

3 回答

?
UYOU

TA贡献1878条经验 获得超4个赞

var func = obj.dbl;
func();

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

val: 4this.val: 4


查看完整回答
反对 回复 2019-02-27
?
繁花如伊

TA贡献2012条经验 获得超12个赞

考虑了很久,执行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

查看完整回答
反对 回复 2019-02-27
?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

var func = obj.dbl; 这一步已近改变了this指向全局
当执行func();的时候this.val = 2;val = 2;都是对全局变量的修改 默认全局为1 相当于12
然后console. log('val:', val) ;console. log( 'this.val:', this.val) ;都是打印修改后的全局变量而已
func();执行一次1 乘以 2 乘以 2 执行两次1 乘以 2 乘以 2 乘以 2 乘以 2

查看完整回答
反对 回复 2019-02-27
  • 3 回答
  • 0 关注
  • 604 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信