
js 中一个关于 this 指向的不解之谜
在探讨 this 指向的复杂性时,我们遇到了一些新问题,让我们尝试逐一解决。
问题 1:
第 2 个代码段等价于第 3 个代码段吗?
function foo() { console.log(this)}var obj = { a: 2, foo: foo}obj.foo()
问题 2:
为什么第 2 个和第 3 个代码段中 this 都指向 window?
function foo() { console.log(this)}var obj = { a: 2, foo: foo() // 第 2 个代码段}var obj = { a: 2, foo: console.log(this) // 第 3 个代码段}obj.foo()
答案:
问题 1:
不,两个代码段不相等。第 2 个代码段中,将括号添加到 foo() 后表明要执行该方法。这样做会将方法返回的结果赋值给 foo 属性。相比之下,第 3 个代码段直接将 console.log(this) 的执行结果赋值给 foo 属性。
问题 2:
thist 指向 window 的原因是:
在第 2 个代码段中,foo() 方法在没有指定调用对象的情况下被执行,导致 this 默认指向 window。在第 3 个代码段中,console.log(this) 的执行结果是一个函数,该函数将在 window 上下文中调用,因此 this 指向 window。
this 指向的规则:
this 指向最近调用的函数的调用对象。如果函数没有被调用或作为构造函数使用,则 this 指向 window(在浏览器环境中)。当使用 obj.foo() 调用方法时,this 指向 obj 对象。在严格模式下,如果一个函数不属于任何对象且没有被调用,则 this 为 undefined。
以上就是JS 中 this 指向的困惑:为什么这两种代码段的 this 都指向 window?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1495787.html
微信扫一扫
支付宝扫一扫