首页 > web前端 > js教程 > 正文

JS 中 this 指向的困惑:为什么这两种代码段的 this 都指向 window?

花韻仙語
发布: 2024-11-05 21:49:08
原创
500人浏览过

JS 中 this 指向的困惑:为什么这两种代码段的 this 都指向 window?

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?的详细内容,更多请关注php中文网其它相关文章!

Windows激活工具
Windows激活工具

Windows激活工具是正版认证的激活工具,永久激活,一键解决windows许可证即将过期。可激活win7系统、win8.1系统、win10系统、win11系统。下载后先看完视频激活教程,再进行操作,100%激活成功。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号