”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 在 JavaScript 中使用“setTimeout”时如何使用“this”保留上下文?

在 JavaScript 中使用“setTimeout”时如何使用“this”保留上下文?

发布于2024-11-09
浏览:177

How to Preserve Context with `this` When Using `setTimeout` in JavaScript?

在 JavaScript 中使用 setTimeout 并通过 this 保存上下文

在 JavaScript 中使用 setTimeout 函数时,必须了解它如何处理这的背景。当在超时回调中调用不同上下文中定义的方法时,这一点变得特别重要。

在提供的代码片段中,方法函数调用 method2,该方法根据传递的 ID 检索图像元素并设置其 src 属性。最初,method2 执行成功。但是,在 setTimeout 延迟之后,会发生错误,因为 method2 函数不再在预期上下文中定义。

出现问题的原因是 setTimeout 创建了一个新的执行上下文,而 this 关键字默认为全局对象。在提供的代码中,使用测试原型的上下文调用方法函数,但是当执行超时回调时,this上下文已更改为全局对象。

解决方案:

要在超时回调中保留 this 的预期上下文,您可以使用 .bind() 方法显式设置上下文的绑定。通过将 .bind(this) 附加到传递给 setTimeout 的函数末尾,您可以确保回调函数中的 this 引用预期的上下文。

更新的代码片段中:

test.prototype.method = function()
{
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method.bind(this), 5000);
    //                                       ^^^^^^^^^^^ <- fix context
};

通过添加.bind(this),回调函数中的this关键字将绑定到测试原型,使得method2即使在setTimeout延迟之后也能在原型方法的上下文中正确调用。

版本声明 本文转载于:1729735296如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-09
  • 如何增加 PHP 最大 POST 变量限制?
    如何增加 PHP 最大 POST 变量限制?
    PHP最大POST变量限制处理具有大量输入字段的POST请求时,当变量数量超过默认值时,会出现常见问题PHP 中的限制。例如,超过 1000 个字段的表单可能只公开 $_POST 数组中的前 1001 个变量。要解决此问题,需要调整 PHP 允许的 POST 变量的最大数量。在版本 5.3.9 中引...
    编程 发布于2024-11-09
  • 如何防止 Pandas 在保存 CSV 时添加索引列?
    如何防止 Pandas 在保存 CSV 时添加索引列?
    避免使用 Pandas 保存的 CSV 中的索引列使用 Pandas 进行修改后保存 csv 文件时,默认行为是包含索引列。为了避免这种情况,可以在使用 to_csv() 方法时将索引参数设置为 False。为了详细说明,请考虑以下命令序列:pd.read_csv('C:/Path/to/file....
    编程 发布于2024-11-09
  • 为什么 OpenX 仪表板显示“错误 330 (net::ERR_CONTENT_DECODING_FAILED)”?
    为什么 OpenX 仪表板显示“错误 330 (net::ERR_CONTENT_DECODING_FAILED)”?
    错误 330 (net::ERR_CONTENT_DECODING_FAILED):解开压缩问题遇到神秘的“错误 330 (net::ERR_CONTENT_DECODING_FAILED)” “在导航到仪表板页面时,必须深入研究根本原因。当 Web 服务器错误识别 HTTP 请求中使用的内容压缩方...
    编程 发布于2024-11-09
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-11-09
  • 如何在Java中使用堆栈将算术表达式解析为树结构?
    如何在Java中使用堆栈将算术表达式解析为树结构?
    在 Java 中将算术表达式解析为树结构从算术表达式创建自定义树可能是一项具有挑战性的任务,特别是在确保树结构时准确反映表达式的操作和优先级。要实现这一点,一种有效的方法是使用堆栈。以下是该过程的逐步描述:初始化:从空堆栈开始。处理令牌:迭代表达式中的每个标记:如果标记是左括号,则压入它如果 tok...
    编程 发布于2024-11-09
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-09
  • 如何进行有替换和无替换的有效加权随机选择?
    如何进行有替换和无替换的有效加权随机选择?
    带替换和不带替换的加权随机选择为了应对编程挑战,我们寻求从列表中进行加权随机选择的有效算法, 带替换的加权选择一种有效的方法带替换的加权选择是别名方法。该技术为每个加权元素创建一组相同大小的箱。通过利用位操作,我们可以有效地索引这些容器,而无需诉诸二分搜索。每个 bin 存储一个百分比,表示原始加权...
    编程 发布于2024-11-09
  • 如何在不依赖框架的情况下确定 DOM 准备情况?
    如何在不依赖框架的情况下确定 DOM 准备情况?
    Document.isReady:DOM 就绪检测的本机解决方案依赖于 Prototype 和 jQuery 等框架来管理 window.onload 事件可能不会总是令人向往。本文探讨了确定 DOM 就绪情况的替代方法,特别是通过使用 document.isReady.查询 Document.is...
    编程 发布于2024-11-09
  • 如何在 Golang 中检索 XML 数组中的所有元素而不仅限于第一个元素?
    如何在 Golang 中检索 XML 数组中的所有元素而不仅限于第一个元素?
    在 XML 中解组数组元素:检索所有元素,而不仅仅是第一个当使用 xml.Unmarshal( 在 Golang 中解组 XML 数组时[]byte(p.Val.Inner), &t),您可能会遇到仅检索第一个元素的情况。要解决此问题,请利用 xml.Decoder 并重复调用其 Decode 方法...
    编程 发布于2024-11-09
  • 带有管理面板的轻量级 Rest Api,可轻松管理食物食谱。
    带有管理面板的轻量级 Rest Api,可轻松管理食物食谱。
    你好, ?所有这篇文章都是关于我刚刚在 Github 上发布的 Django Rest Framework API。 如果您正在寻找一些简单而高效的 API 来从管理面板管理食物食谱并将其返回以供客户端使用,那么此存储库适合您。 该代码是轻量级的,可以在任何低功耗迷你 PC(如 Raspberry...
    编程 发布于2024-11-09
  • 如何使用正则表达式匹配带有或不带有可选 HTTP 和 WWW 前缀的 URL?
    如何使用正则表达式匹配带有或不带有可选 HTTP 和 WWW 前缀的 URL?
    使用可选 HTTP 和 WWW 前缀匹配 URL正则表达式是执行复杂模式匹配任务的强大工具。当涉及到匹配 URL 时,格式通常会有所不同,例如是否包含“http://www”。 使用正则表达式的解决方案匹配带或不带“http://www”的 URL。前缀,可以使用以下正则表达式:((https?|f...
    编程 发布于2024-11-09
  • 如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下确定文件类型?
    如何在不依赖扩展名的情况下检测文件类型除了检查文件的扩展名之外,确定文件是 mp3 还是图像格式是很有价值的编程中的任务。这是一个不依赖扩展的全面解决方案:PHP >= 5.3:$mimetype = finfo_fopen(fopen($filename, 'r'), FILEINFO_MIME_...
    编程 发布于2024-11-09
  • 在 JavaScript 中实现斐波那契数列:常见方法和变体
    在 JavaScript 中实现斐波那契数列:常见方法和变体
    作为开发人员,您可能遇到过编写函数来计算斐波那契数列中的值的任务。这个经典问题经常出现在编码面试中,通常要求递归实现。然而,面试官有时可能会要求具体的方法。在本文中,我们将探讨 JavaScript 中最常见的斐波那契数列实现。 什么是斐波那契数列? 首先,让我们回顾一下。斐波那契数...
    编程 发布于2024-11-09
  • 如何使用 .htaccess 更改共享服务器上的 PHP 版本?
    如何使用 .htaccess 更改共享服务器上的 PHP 版本?
    在共享服务器上通过 .htaccess 更改 PHP 版本如果您正在操作共享服务器并且需要更改 PHP 版本,可以通过 .htaccess 文件来做到这一点。这允许您为您的网站运行特定的 PHP 版本,同时服务器维护其默认版本。要切换 PHP 版本,请按照下列步骤操作:找到 . htaccess 文...
    编程 发布于2024-11-09

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

Copyright© 2022 湘ICP备2022001581号-3