”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么 JavaScript 中的“this”运算符不一致以及如何解决?

为什么 JavaScript 中的“this”运算符不一致以及如何解决?

发布于2024-11-08
浏览:135

Why is the \

在 Javascript 中,为什么“this”运算符不一致?

在 JavaScript 中,“this”运算符表现出不同的行为,具体取决于调用上下文。这可能会导致混乱和意外结果,特别是在使用回调和对象时。

调用模式和“this”绑定

“this”运算符绑定到函数调用时的对象或类,this 绑定由调用模式决定:

  • 方法: 当作为对象的方法调用时,“this”指的是对象本身。
  • 函数: 当作为独立函数调用时,“this”引用全局范围(浏览器中的窗口对象)。
  • 构造函数: 当使用“new”关键字调用时,会创建一个新对象,并且“this”指向该对象。
  • Apply: “apply”方法允许显式设置“this”并在数组中传递参数。

回调难题

当方法的回调作为函数调用时,就会出现问题。由于回调不是作为方法调用的,因此“this”指的是全局范围,而不是它最初打算的对象。

最佳实践

维护的一个策略回调中“this”绑定的一致性是使用“var that = this;”图案。这将对“this”(对象)的引用分配给一个新变量(that),然后可以在回调中使用该变量。

另一个推荐的方法是拥抱 JavaScript 的函数式编程方面并避免依赖类和继承模式。通过使用纯函数和高阶函数,您可以将逻辑与对象状态分离,并实现更加模块化和可预测的代码。

此外,考虑使用 JavaScript 框架,该框架提供了处理“this”绑定和对象的机制。以一致的方式进行面向编程。请记住仔细查看框架的文档和怪癖,以避免意外行为。

版本声明 本文转载于:1729561575如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 为什么嵌入框阴影在透明背景的图像上消失?
    为什么嵌入框阴影在透明背景的图像上消失?
    了解图像上的插入框阴影问题在网页设计中,使用插入框阴影在元素内创建深度和尺寸是一种常见技术。然而,在处理包含图像的容器时,事情并不总是那么简单。当嵌入框阴影似乎在嵌入图像上消失时,就会出现问题。隐形阴影的情况考虑原始问题中提供的示例:body { background-color: #00000...
    编程 发布于2024-11-08
  • 如何在 ReactJS 中维护悬停状态:解决事件注册问题
    如何在 ReactJS 中维护悬停状态:解决事件注册问题
    在 ReactJS 中维护悬停状态:解决事件注册问题使用内联样式时,您会遇到 ReactJS 中悬停和活动事件的问题,因为 onMouseEnter 和 onMouseLeave 方法被证明是不可靠的。要解决此问题,请考虑利用这些事件之一处理程序:onMouseDownonMouseEnteronM...
    编程 发布于2024-11-08
  • 如何在 JavaScript 中准确检查 Null 值和空字符串?
    如何在 JavaScript 中准确检查 Null 值和空字符串?
    检查 JavaScript 中的 Null 值在 JavaScript 中,确定值是否为 null 有时会令人困惑。为了提供更深入的理解,本文将深入研究在 JavaScript 上下文中检测空值的细节。检查空值提供的代码片段旨在检查跨多个变量的 null 值:if (pass == null || ...
    编程 发布于2024-11-08
  • PHP 4 快速部署
    PHP 4 快速部署
    Servbay 已成为高效配置开发环境的领先工具。在本指南中,我们将引导您完成快速、安全地部署 PHP 8.1 的过程,展示 Servbay 对简化部署的承诺。 先决条件 确保您的计算机上安装了 Servbay。您可以从 Servbay 官方网站轻松下载。安装过程人性化;只需按照安装...
    编程 发布于2024-11-08
  • 如何绕过验证码
    如何绕过验证码
    No matter how many times people wrote that the captcha has outlived itself long time ago and no longer works as effectively as its developers would ha...
    编程 发布于2024-11-08
  • 使用 super 调用超类构造函数
    使用 super 调用超类构造函数
    子类可以使用 super(parameter-list);. 形式调用其超类定义的构造函数 parameter-list 必须指定超类构造函数所需的参数。 子类构造函数中执行的第一条语句必须始终是 super(); (或者 super(parameter-list); 如果需要传递参数). 以下是...
    编程 发布于2024-11-08
  • 你能比较 C++ 中不同容器的迭代器吗?
    你能比较 C++ 中不同容器的迭代器吗?
    比较来自不同容器的迭代器:一个警示故事在 C 中,迭代器提供了一种强大的遍历集合的机制。然而,在使用来自不同容器的迭代器时,重要的是要意识到这些限制。比较来自不同容器的迭代器是否合法的问题经常出现。考虑以下示例:std::vector<int> foo; std::vector<i...
    编程 发布于2024-11-08
  • 帮助 FastAPI:如何为文档翻译做出贡献
    帮助 FastAPI:如何为文档翻译做出贡献
    One of the great features of FastAPI is its great documentation ?. But wouldn't it be better if more people around the world had access to this docume...
    编程 发布于2024-11-08
  • 如何使用 CSS 和 AngularJS 创建垂直 HTML 表格?
    如何使用 CSS 和 AngularJS 创建垂直 HTML 表格?
    垂直 HTML 表格创建具有垂直行的 HTML 表格提供了一种独特的方式来显示数据,行标题位于左侧而不是顶部。要实现此目的,可以应用 CSS 样式来转换表格的结构。CSS 样式要将表格行呈现为垂直列,请遵循以下 CSS 规则可以使用:tr { display: block; float: l...
    编程 发布于2024-11-08
  • 通过自定义 Hooks 在 React 中重用逻辑:实用指南
    通过自定义 Hooks 在 React 中重用逻辑:实用指南
    自定义钩子是 React 中的一项强大功能,与 React 内置钩子不同,它用于更具体的目的,并且它是通过将常见功能封装到独立函数中来完成的。自定义挂钩促进可重用性、改进组件组织并整体增强代码可维护性。 在本指南中,我们将深入探讨使用自定义钩子的目的,了解创建自定义钩子的基础知识以及如何使用其他组件...
    编程 发布于2024-11-08
  • 使用 ReactJS 构建免费的 AI 图像生成器
    使用 ReactJS 构建免费的 AI 图像生成器
    开发者们大家好, 今天,我将向您展示如何使用 ReactJS 创建图像生成器,并且完全可以免费使用,这要感谢黑森林实验室和 Together AI。 第 1 步:设置项目 在本教程中,我们将使用 Vite 来初始化应用程序并使用 Shadcn 来初始化 UI。我假设您已经设置了项目并...
    编程 发布于2024-11-08
  • 字符串中的串联或大括号:哪种方法可以优化性能和美观?
    字符串中的串联或大括号:哪种方法可以优化性能和美观?
    字符串中的变量连接与大括号:评估性能和美观在字符串操作领域,开发人员经常面临两难境地:他们应该连接字符串中的变量还是选择花括号?每种方法都有自己的优点和缺点,我们将深入研究这些优点和缺点,以提供明智的决策。串联:传统方法串联涉及使用以下方法将变量附加到字符串这 '。'操作员。虽然这种...
    编程 发布于2024-11-08
  • 我尝试过花岗岩。
    我尝试过花岗岩。
    花岗岩3.0 Granite 3.0 是一个开源、轻量级的生成语言模型系列,专为一系列企业级任务而设计。它原生支持多语言功能、编码、推理和工具使用,使其适合企业环境。 我测试了运行这个模型,看看它可以处理哪些任务。 环境设置 我在Google Colab中设置了Gr...
    编程 发布于2024-11-08
  • 掌握 JavaScript 函数:开发人员综合指南
    掌握 JavaScript 函数:开发人员综合指南
    JavaScript Functions A JavaScript function is a block of code designed to perform a particular task. A JavaScript function is executed when "...
    编程 发布于2024-11-08
  • Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 中的缓存不仅仅是为了节省时间,还在于减少冗余网络请求、保持数据新鲜并使您的应用程序像摇滚明星一样运行。 无论您是想将数据缓存更长时间还是按需刷新,Next.js 都能为您提供所需的所有工具。在本文中,我们将详细介绍如何在 Next.js 中有效地使用缓存 Next.js 扩展了 f...
    编程 发布于2024-11-08

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

Copyright© 2022 湘ICP备2022001581号-3