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

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

花韻仙語
发布: 2024-11-06 08:52:33
原创
897人浏览过

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 指向该对象。

以上就是JS 中 this 指向的疑惑解析:obj.foo() 和 foo() 为什么指向 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号