”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 理解 JavaScript 中的“this”关键字

理解 JavaScript 中的“this”关键字

发布于2024-08-07
浏览:991

Understanding the `this` Keyword in JavaScript

JavaScript 中的 this 关键字对于新开发人员来说可能是最令人困惑的概念之一。它的价值会根据它的使用位置而变化,因此了解它在不同环境中的行为至关重要。本文将通过探讨 this 关键字在各种场景中的使用来揭开 this 关键字的神秘面纱。

这是什么?

在 JavaScript 中,this 指的是执行函数的上下文。它提供了一种从对象本身内部访问对象的属性和方法的方法。

全球背景

当在全局上下文中(在任何函数或对象之外)使用时,this 指的是全局对象。在网络浏览器中,全局对象是 window.

console.log(this); // In a browser, this will log the window object

函数上下文

当在函数内部使用时,这取决于函数的调用方式。

常规函数调用

在常规函数调用中,this 指的是全局对象(或在严格模式下未定义)。

function showThis() {
  console.log(this);
}

showThis(); // Logs window (or undefined in strict mode)

方法调用

当函数作为对象的方法被调用时,this 指的是对象本身。

const person = {
  name: 'Alice',
  greet: function() {
    console.log(this.name);
  }
};

person.greet(); // Logs "Alice"

构造函数上下文

当函数作为带有 new 关键字的构造函数时,this 指的是新创建的实例。

function Person(name) {
  this.name = name;
}

const bob = new Person('Bob');
console.log(bob.name); // Logs "Bob"

箭头功能

箭头函数有不同的行为。他们没有自己的 this 上下文;相反,它们从周围的词汇上下文继承它。

const obj = {
  name: 'Carol',
  regularFunction: function() {
    console.log(this.name);
  },
  arrowFunction: () => {
    console.log(this.name);
  }
};

obj.regularFunction(); // Logs "Carol"
obj.arrowFunction();   // Logs undefined (or the global object in non-strict mode)

事件处理程序

在事件处理程序中,这是指接收事件的元素。

document.getElementById('myButton').addEventListener('click', function() {
  console.log(this); // Logs the button element
});

显式绑定

JavaScript提供了使用call、apply和bind显式设置this值的方法。

致电并申请

call 和 apply 方法允许您调用具有指定 this 值的函数。

function introduce() {
  console.log(`Hello, my name is ${this.name}`);
}

const person = { name: 'Dave' };

introduce.call(person); // Logs "Hello, my name is Dave"
introduce.apply(person); // Logs "Hello, my name is Dave"

call 和 apply 之间的区别在于它们处理参数的方式。 call 单独接受参数,而 apply 将它们作为数组接受。

绑定

bind 方法创建一个新函数,调用该函数时,会将其 this 值设置为提供的值。

function introduce() {
  console.log(`Hello, my name is ${this.name}`);
}

const person = { name: 'Eve' };

const boundIntroduce = introduce.bind(person);
boundIntroduce(); // Logs "Hello, my name is Eve"

结论

理解 this 关键字对于掌握 JavaScript 至关重要。通过认识它在不同上下文中的行为方式,您可以编写更可预测和可维护的代码。无论您使用方法、构造函数还是箭头函数,了解其运作方式都将帮助您避免常见陷阱并有效利用其功能。

版本声明 本文转载于:https://dev.to/mdhassanpatwary/understanding-the-this-keyword-in-javascript-12ea?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 使用 VAKX 构建您的无代码 AI 代理
    使用 VAKX 构建您的无代码 AI 代理
    If you’ve been keeping up with the AI space, you already know that AI agents are becoming a game-changer in the world of automation and customer inter...
    编程 发布于2024-11-05
  • 这里是我如何在 jQuery Datatable 中实现基于游标的分页。
    这里是我如何在 jQuery Datatable 中实现基于游标的分页。
    在 Web 应用程序中处理大型数据集时,分页对于性能和用户体验至关重要。标准的基于偏移量的分页(通常与数据表一起使用)对于大型数据集可能效率低下。 基于游标的分页提供了一种性能更高的替代方案,特别是在处理实时更新或大量数据加载时。在本文中,我将引导您了解如何在 jQuery DataTable 中...
    编程 发布于2024-11-05
  • 为什么同步引擎可能是 Web 应用程序的未来
    为什么同步引擎可能是 Web 应用程序的未来
    在不断发展的 Web 应用程序世界中,效率、可扩展性和无缝实时体验至关重要。传统的 Web 架构严重依赖于客户端-服务器模型,这些模型可能难以满足现代对响应能力和同步的需求。这就是同步引擎发挥作用的地方,它为开发人员当今面临的许多挑战提供了一个有前途的解决方案。但同步引擎到底是什么?为什么它们可能是...
    编程 发布于2024-11-05
  • Python 计算机视觉简介(第 1 部分)
    Python 计算机视觉简介(第 1 部分)
    注意:在这篇文章中,我们将仅使用灰度图像以使其易于理解。 什么是图像? 图像可以被认为是值的矩阵,其中每个值代表像素的强度。图像格式主要分为三种类型: Binary:此格式的图像由值为 0(黑色)和 1(白色)的单个二维矩阵表示。这是最简单的图像表示形式。 Grey-Scale:在此...
    编程 发布于2024-11-05
  • 网站 HTML 代码
    网站 HTML 代码
    我一直在尝试建立一个与航空公司相关的网站。我只是想确认我是否可以使用人工智能生成代码来生成整个网站。 HTML 网站是否兼容博客,或者我应该使用 JavaScript?这是我用作演示的代码。 <!DOCTYPE html> <html lang="en">[](url) &l...
    编程 发布于2024-11-05
  • 像程序员一样思考:学习 Java 基础知识
    像程序员一样思考:学习 Java 基础知识
    本文介绍了 Java 编程的基本概念和结构。它首先介绍了变量和数据类型,然后讨论了操作符和表达式,以及控制流流程。其次,它解释了方法和类,然后介绍了输入和输出操作。最后,本文通过一个工资计算器的实际示例展示了这些概念的应用。像程序员一样思考:掌握 Java 基础1. 变量和数据类型Java 使用变量...
    编程 发布于2024-11-05
  • PHP GD 可以比较两个图像的相似性吗?
    PHP GD 可以比较两个图像的相似性吗?
    PHP GD 可以确定两个图像的相似度吗?正在考虑的问题询问是否可以使用以下命令确定两个图像是否相同PHP GD 通过比较它们的差异。这需要获取两个图像之间的差异并确定它是否完全由白色(或任何统一的颜色)组成。根据提供的答案,散列函数(如其他响应所建议的那样)不适用于此语境。比较必须涉及图像内容而不...
    编程 发布于2024-11-05
  • 使用这些键编写高级测试(JavaScript 中的测试需求)
    使用这些键编写高级测试(JavaScript 中的测试需求)
    在本文中,您将学习每个高级开发人员都应该了解的 12 个测试最佳实践。您将看到 Kent Beck 的文章“Test Desiderata”的真实 JavaScript 示例,因为他的文章是用 Ruby 编写的。 这些属性旨在帮助您编写更好的测试。了解它们还可以帮助您在下一次工作面试中取得好成绩。 ...
    编程 发布于2024-11-05
  • 通过将 matlab/octave 算法移植到 C 来实现 AEC 的最佳解决方案
    通过将 matlab/octave 算法移植到 C 来实现 AEC 的最佳解决方案
    完毕!对自己有点印象。 我们的产品需要回声消除功能,确定了三种可能的技术方案, 1)利用MCU检测audio out和audio in的音频信号,编写算法计算两侧声音信号的强度,根据audio out和audio in的强弱在两个通道之间进行可选的切换,实现半双工通话效果,但现在市场上都是全双工通话...
    编程 发布于2024-11-05
  • 逐步构建网页:探索 HTML 中的结构和元素
    逐步构建网页:探索 HTML 中的结构和元素
    ?今天标志着我软件开发之旅的关键一步! ?我编写了第一行代码,深入研究了 HTML 的本质。涵盖的元素和标签。昨天,我探索了构建网站的拳击技术,今天我通过创建页眉、页脚和内容区域等部分将其付诸实践。我还添加了各种 HTML 元素,包括图像元素和链接元素,甚至尝试在单页网站上进行内部链接。看到这些部分...
    编程 发布于2024-11-05
  • 项目创意不一定是独特的:原因如下
    项目创意不一定是独特的:原因如下
    在创新领域,存在一个常见的误解,即项目创意需要具有开创性或完全独特才有价值。然而,事实并非如此。我们今天使用的许多成功产品与其竞争对手共享一组核心功能。让他们与众不同的不一定是想法,而是他们如何执行它、适应用户需求以及在关键领域进行创新。 通讯应用案例:相似但不同 让我们考虑一下 M...
    编程 发布于2024-11-05
  • HackTheBox - Writeup 社论 [已退休]
    HackTheBox - Writeup 社论 [已退休]
    Neste writeup iremos explorar uma máquina easy linux chamada Editorial. Esta máquina explora as seguintes vulnerabilidades e técnicas de exploração: S...
    编程 发布于2024-11-05
  • 强大的 JavaScript 技术可提升您的编码技能
    强大的 JavaScript 技术可提升您的编码技能
    JavaScript is constantly evolving, and mastering the language is key to writing cleaner and more efficient code. ?✨ Whether you’re just getting starte...
    编程 发布于2024-11-05
  • 如何在 ReactJS 中创建可重用的 Button 组件
    如何在 ReactJS 中创建可重用的 Button 组件
    按钮无疑是任何 React 应用程序中重要的 UI 组件,按钮可能用于提交表单或打开新页面等场景。您可以在 React.js 中构建可重用的按钮组件,您可以在应用程序的不同部分中使用它们。因此,维护您的应用程序将变得更加简单,并且您的代码将保持 DRY(不要重复自己)。 您必须首先在组件文件夹中创建...
    编程 发布于2024-11-05
  • 如何在 Apache HttpClient 4 中实现抢占式基本身份验证?
    如何在 Apache HttpClient 4 中实现抢占式基本身份验证?
    使用 Apache HttpClient 4 简化抢占式基本身份验证虽然 Apache HttpClient 4 已经取代了早期版本中的抢占式身份验证方法,但它提供了替代方法以实现相同的功能。对于寻求直接抢占式基本身份验证方法的开发人员,本文探讨了一种简化方法。为了避免向每个请求手动添加 Basic...
    编程 发布于2024-11-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3