您好,匿名用户

箭头函数this指向的问题

0 投票
function foo() {
  setTimeout(() => {
    console.log('id:', this.id);
  }, 100);
}

var id = 21;

foo.call({ id: 42 });
// id: 42

箭头函数内部的this是指向定义时所在的对象,不是执行时所在的对象。按照这个道理的话,setTimeout内部的函数不管是不是箭头函数应该都是指向window啊。定义的时候,内部的this不应该指向window,执行的时候才是指向调用的对象{ id: 42 }吗?求教

用户头像 提问 5月27日 @ Kennen 上士 (1,557 威望)
分享到:

1个回答

0 投票
 
最佳答案

你可以理解成箭头函数写在哪里,就获取哪里的this
这里明显就直接读取foo的执行环境中的this,而foo被你强制绑定到{ id: 42 }上,所以this自然指向这个对象。

用户头像 回复 5月27日 @ Varus 中士 (1,216 威望)
选中 5月16日 @Kennen
提一个问题:

相关问题

0 投票
1 回复 16 阅读
用户头像 提问 5月27日 @ 切糕 中士 (1,296 威望)
0 投票
1 回复 17 阅读
0 投票
1 回复 56 阅读
用户头像 提问 2017年 3月5日 @ Udyr 中士 (1,446 威望)
0 投票
1 回复 231 阅读
用户头像 提问 2017年 3月23日 @ Amumu 上士 (1,535 威望)
0 投票
1 回复 98 阅读
用户头像 提问 2017年 3月11日 @ Amumu 上士 (1,535 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

IT技术交流群 - 随意问
欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...