0

0

如何在回调中访问正确的“this”?

WBOY

WBOY

发布时间:2023-08-24 09:53:09

|

1057人浏览过

|

来源于tutorialspoint

转载

如何在回调中访问正确的“this”?

在本教程中,我们将了解如何在回调中访问正确的“this”。

“这个”关键字

每个函数都包含一个名为 this 的关键字,也称为“上下文”,其值由函数的调用方式决定,而不是由函数的定义方式、时间或位置决定。与其他变量不同,它不受词法作用域的影响。与其他语言相比,当使用函数的“this”关键字时,JavaScript 的行为略有不同。在严格模式和非严格模式之间,还有一些进一步的变化。

函数最常被调用的方式决定了“this”的值(运行时绑定)。每次调用该函数时它都可能会发生变化,并且在执行时不能通过赋值来更改。函数被调用的次数,bind() 方法可以设置该值,因为箭头函数不提供自己的“this”绑定(它保留封闭词法上下文的“this”值)。

什么叫回调?

从另一个函数接收参数的函数称为回调,通常在稍后的外部函数中使用。高阶函数是一个术语,用于描述接受回调的外部函数。

回调有自己的一组方法和属性,因为函数是 JavaScript 中的对象。在高阶函数内执行时分配给回调的“this”属性完全取决于回调的制作方式,而不是定义的位置、方式或时间。

通过检查调用回调的高阶函数,我们可以确定回调中的“this”值。封闭函数的实际定义可能包括本地范围的属性,这是回调中 this 问题的主要原因。但是,由于回调的上下文根据其调用方式而动态变化,因此当通过回调中的“this”绑定访问该属性时,它不存在。

现在我们将学习在回调中访问正确的“this”的方法。

EasySub – AI字幕生成翻译工具
EasySub – AI字幕生成翻译工具

EasySub 是一款在线 AI 字幕生成器。 它提供AI语音识别、AI字幕生成、AI字幕翻译,本来就很简单的视频剪辑。

下载

使用“self”模式

创建一个名为 self 的变量,并在声明函数的范围内为其赋予 this 值是一种典型的模式。我们可以通过创建一个名为 self 的新变量(或任何其他有效的变量名称都可以)并为其赋予“this”值来实现所需的行为。

示例



   

'this' Inside a Callback using the 'self' pattern

Welcome to Tutorialspoint!

使用箭头函数

ECMAScript 6 见证了 JavaScript 箭头函数的首次亮相。它们没有自己的绑定,是传统函数表达式的更简洁的替代方案。这确保了如果在箭头函数内部引用 this,它会作为常规变量在范围内进行搜索。

示例



   

'this' Inside a Callback using the arrow function

Welcome to Tutorialspoint!

使用另一个变量来存储“this”对象

该对象链接到它,这通常是当我们尝试在回调中访问它时真正想要访问的对象。创建变量并在回调作用域之前存储其值是实现此目的的一种方法(尽管有些程序员不愿意这样做,因为它看起来很混乱)。

有些人将其称为“that”或“self”,但只要术语明确,就没有关系。此解决方法非常有效,因为该变量符合词法范围要求,因此可在回调中使用。您仍然可以访问回调的动态 this 绑定,这是这种方式的另一个好处。

示例



   

'this' Inside a Callback using the another variable to store the 'this' object

Welcome to Tutorialspoint!

使用显式地将 this 绑定到对象

当我们定义回调时,我们可以声明我们想要什么。我们可以使用bind()方法设置“this”值,并确保它在整个函数执行过程中保持这种状态,无论它是如何或在哪里调用或传递的。

bind() 方法在每个函数中都可用,并使用连接到给定对象的“this”属性创建一个新函数。返回函数和原始函数之间的唯一区别是您可以完全控制“this”属性指向的内容。

示例



   

'this' Inside a Callback using explicitly binding this to an object

Welcome to Tutorialspoint!

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

84

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

24

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

35

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

56

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

26

2026.01.15

热门下载

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

精品课程

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

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