Hello! 欢迎来到小浪云数据!

JS 中 this 指向的疑惑解析:obj.foo() 和 foo() 为什么指向 window 对象?


JS 中 this 指向的疑惑解析:obj.foo() 和 foo() 为什么指向 window 对象?

js中 this 指向的疑惑解析

对于 this 指向的问题,有开发者提出疑惑:

function foo() {     console.log(this); }  var obj = {     a: 2,     foo: foo }; obj.foo();
登录后复制

疑问 1:
obj.foo() 等价于 foo()?

疑问 2:
为什么 obj.foo() 和 foo: console.log(this) 都指向 window 对象

解答:

解答 1:
不等价。函数名后面加括号表示立即执行,而 obj.foo() 只是将 foo() 赋值给 obj 的 foo 属性。

解答 2:
obj.foo() 实际执行的是 obj 中的 foo 方法,此时 this 指向 obj。而 foo: console.log(this) 将 console.log(this) 的值直接赋值给 obj.foo,与 this 指向无关。

this 指向规则:

  • 一般来说,this 指向调用它的对象。
  • 如果函数直接被调用,this 指向 window 对象(若在严格模式下,指向 undefined)。
  • 如果函数作为对象的方法被调用,this 指向该对象。

相关阅读