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

javascript中this指向什么_如何改变它

幻影之瞳
发布: 2025-12-18 22:56:02
原创
133人浏览过
JavaScript 中的 this 指向取决于函数调用方式而非定义方式:普通调用指向全局对象(非严格模式)或 undefined(严格模式),对象方法调用指向该对象,new 调用指向新实例,箭头函数继承外层 this,事件处理中指向触发元素。

javascript中this指向什么_如何改变它

JavaScript 中的 this 指向谁,**取决于函数如何被调用,而不是如何被定义**。它不是固定绑定在函数上,而是在运行时动态确定的。理解 this 的核心,就是看“谁调用了这个函数”。

常见调用方式决定 this 指向

函数有几种典型调用形式,每种对应不同的 this 绑定规则:

  • 普通函数调用(独立调用):比如 foo(),在非严格模式下 this 指向全局对象(浏览器中是 window),严格模式下是 undefined
  • 对象方法调用:比如 obj.method(),this 指向调用它的那个对象(这里是 obj
  • 构造函数调用(new):比如 new Foo(),this 指向新创建的实例对象
  • 箭头函数:没有自己的 this,它会沿作用域链向上查找,继承外层普通函数的 this(或全局环境)
  • 事件处理函数:比如 btn.onclick = handler,this 指向触发事件的 DOM 元素(即 btn

手动改变 this 的三种方法

当默认绑定不符合需求时,可以用以下 API 显式控制 this:

  • call(thisArg, arg1, arg2, ...):立即执行函数,并把 this 设为 thisArg,参数逐个传入
  • apply(thisArg, [argsArray]):功能同 call,但参数以数组形式传入
  • bind(thisArg, arg1, arg2, ...):不执行函数,而是返回一个新函数,该函数永久绑定 this 和部分参数(柯里化)

例如:obj.method.call(otherObj, 'a', 'b')method 内部的 this 指向 otherObj

立即学习Java免费学习笔记(深入)”;

Find JSON Path Online
Find JSON Path Online

Easily find JSON paths within JSON objects using our intuitive Json Path Finder

Find JSON Path Online 193
查看详情 Find JSON Path Online

容易出错的场景与建议

实际开发中,this 丢失最常发生在回调、定时器、解构赋值等上下文断裂的场合:

  • 把对象方法赋给变量后调用:const fn = obj.method; fn(); → this 不再是 obj
  • 作为回调传入 setTimeout 或事件监听器:setTimeout(obj.method, 100) → this 变成全局或 undefined
  • 解构后调用:const { method } = obj; method(); → 同样丢失绑定

解决办法包括:用箭头函数包裹、用 bind 预绑定、改用 class 字段语法(method = () => {})、或在调用时显式 call/apply。

基本上就这些。this 不复杂但容易忽略调用现场,养成“看调用点”的习惯比死记规则更可靠。

以上就是javascript中this指向什么_如何改变它的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

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

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