0

0

JS中的this指向什么?怎么控制?

下次还敢

下次还敢

发布时间:2025-06-06 22:30:02

|

1017人浏览过

|

来源于php中文网

原创

this的指向取决于函数调用方式。1. 默认情况下,普通函数的this指向全局对象(如浏览器中为window),若作为对象方法调用则指向该对象,若通过new调用则指向新对象实例;2. 箭头函数无自身this,继承外层作用域的this;3. 可使用call、apply或bind手动绑定this,其中call和apply立即调用函数并分别以参数列表和数组传参,bind返回一个绑定后的新函数;4. 常见问题出现在事件监听或回调中,可通过bind或箭头函数包裹来保持this指向预期对象。掌握这些规则可有效避免this带来的混淆与错误。

JS中的this指向什么?怎么控制?

在JavaScript中,this的指向是很多人刚开始学习时容易混淆的地方。它的值不是固定不变的,而是根据函数被调用的方式动态决定的。理解这一点,对写出稳定、可维护的代码非常重要。


1. this默认指向谁?

函数中的this指向取决于它被如何调用,而不是在哪里定义的。

  • 在普通函数中(非箭头函数),this默认指向全局对象,在浏览器中就是window
  • 如果函数是在某个对象的方法中被调用的,那么this就会指向那个对象。
  • 如果函数作为构造函数通过new调用,this会指向新创建的对象实例。

举个例子:

const obj = {
  name: 'Tom',
  sayName: function() {
    console.log(this.name);
  }
};

obj.sayName(); // 输出 'Tom',this指向obj

但如果把方法单独拿出来调用:

const func = obj.sayName;
func(); // 输出 undefined 或者 window.name(如果存在)

这时候this就不再指向obj了。


2. 箭头函数的this怎么算?

箭头函数没有自己的this,它会捕获外层作用域的this值。

也就是说,箭头函数内部的this其实是它外层普通函数或全局作用域的this

比如:

const obj = {
  name: 'Jerry',
  sayName: () => {
    console.log(this.name); // 这里的 this 指向全局对象
  }
};

obj.sayName(); // 输出 undefined 或 window.name

即使sayNameobj的一个属性,由于它是箭头函数,this仍然不会指向obj

所以如果你希望this能绑定到当前对象,尽量不要使用箭头函数作为对象的方法。

Face++旷视
Face++旷视

Face⁺⁺ AI开放平台

下载

3. 如何手动控制this的指向?

JS提供了三种方法可以显式指定函数执行时的this

  • call
  • apply
  • bind

它们的区别在于传参方式和调用时机:

  • call(obj, arg1, arg2):立即调用函数,参数依次传递。
  • apply(obj, [arg1, arg2]):立即调用,参数以数组形式传入。
  • bind(obj, arg1, arg2):返回一个新函数,之后再调用。

例如:

function greet(greeting, punctuation) {
  console.log(`${greeting}, ${this.name}${punctuation}`);
}

const person = { name: 'Alice' };

greet.call(person, 'Hello', '!'); // Hello, Alice!
greet.apply(person, ['Hi', '.']); // Hi, Alice.
const sayHello = greet.bind(person, 'Hey');
sayHello('!!!'); // Hey, Alice!!!

这些方法常用于回调函数、事件处理等场景中,用来“锁定”this的指向。


4. 常见的坑:事件监听与回调中的this

在DOM事件监听或异步操作中,this容易丢失预期的指向。

比如:

const button = document.querySelector('#btn');
button.addEventListener('click', obj.sayName);
// 此时点击按钮输出 undefined,因为 this 指向 button 元素

解决办法通常是用bind提前绑定上下文,或者用闭包保存this

button.addEventListener('click', obj.sayName.bind(obj));

或者用箭头函数包裹:

button.addEventListener('click', () => obj.sayName());

不过要注意,这种方式其实是在调用函数,而不是绑定函数本身。


基本上就这些。
this看起来简单,但稍不注意就容易出错。关键在于记住一句话:函数怎么调用决定了this是谁。掌握不同调用方式下的规则,并学会用call/apply/bind来控制,就能避免很多问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

153

2025.07.29

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6305

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

494

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

Js中concat和push的区别
Js中concat和push的区别

Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.09.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 10.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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