理解 JavaScript 对象和函数中的“this”

理解 javascript 对象和函数中的“this”

js 对象作用域中的 this 关键字

在 javascript 中,了解 this 关键字的内容、方式和位置可能是编写实际有效的代码和在编码时抓狂的区别

这个关键字

在javascript中,这是一个关键字(保留字),也就是说,它不能用作变量名。

在 javascript 代码中,这用于表示范围。简而言之,作用域是包含一行或多行代码的代码块。它可以表示整个代码(全局范围)或大括号内的代码行 {…}

    var a = 1;    //varaible "a" can be accessed any where within the global scope    function sayhello(){        var message = "hello";        console.log(message);    };    //the variable "message" is not accessible in the global scope    //varaible "a" can be accessed any where within the global scope

这在行动中

    var a = 1;    console.log(this.a); // output is 1; this refers to the global scope here, the variable "a" is in the global scope.    function sayhello(){        var message = "hello";        console.log(this.message);    };    sayhello(); // undefined

您可能想知道为什么上面代码片段中的 sayhello() 函数返回未定义,因为 this 引用了 sayhello() 函数作用域。在你急于说之前,这是 javascript 的另一个怪癖。让我们深入探讨一下。

    var a = 1;    console.log(this.a); // output is 1; this refers to the global scope here, the variable "a" is in the global scope.    function sayhello(){        var message = "hello";        console.log(this.message);    };    sayhello(); // undefined

sayhello() 函数在全局范围内执行,这意味着 sayhello() 的执行会将其解析为全局范围(window 对象;更像是 window.message)。全局作用域中没有名为 message 的变量,因此它返回 undefined (您可以尝试将名为 message 的变量添加到全局作用域中,看看会发生什么。)。可能的解决方案如下所示:

    var person = {        message: "hello",        sayhello: function(){            console.log(this.message);        }    };    person.sayhello(); // hello

这里,sayhello() 函数是 person 对象中的一个属性,执行该函数会将其解析为 person 对象的范围,而不是 window 对象。 message 是 person 对象中的一个变量(对象属性),因此它返回分配给它的值。

虽然上述情况在现实场景中可能没有必要,但这只是对其底层工作原理的基本解释。

让我们看另一个例子:

即构数智人 即构数智人

即构数智人是由即构科技推出的AI虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

即构数智人 36 查看详情 即构数智人

    const obj = {        a: 1,        b: function() {            return this.a;        },        c: () => {            return this.a;        }    };    // Output 1: 1    console.log(obj.b());      // Output 2: undefined    console.log(obj.c());      const test = obj.b;    // Output 3: undefined    console.log(test());        const testArrow = obj.c;    // Output 4: undefined    console.log(testArrow());

输出1

obj.b() 执行函数,this 解析为 obj 对象范围并返回 a

立即学习“Java免费学习笔记(深入)”;

的值

输出2

箭头函数将其解析为全局范围,即使它们是在对象内声明的。这里,this 解析为全局作用域(窗口),变量 a 不存在于全局作用域中,因此返回 undefined。

输出3

obj.b从obj对象返回一个函数(它不执行它;函数调用中的括号表示执行),返回的函数被分配给测试变量,并且该函数在全局范围(窗口)中执行,变量 a 在全局作用域中不存在,因此返回 undefined。

输出4

obj.c从obj对象返回一个函数(它不执行它;函数调用中的括号表示执行),返回的函数被分配给testarrow变量,并且该函数在全局范围(窗口)中执行,箭头函数通常会将 this 解析到全局作用域,变量 a 不存在于全局作用域中,因此返回 undefined。

好了,伙计们。我希望您已经了解 javascript 中的工作原理的基础知识。不再在箭头函数中使用 this,对吗?就范围内的使用而言,我们也不应该失眠。

以上就是理解 JavaScript 对象和函数中的“this”的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/437673.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 17:04:13
下一篇 2025年11月7日 17:05:18

相关推荐

  • 如何将 C++ 框架与物联网技术集成?

    将 c++++ 框架与物联网技术集成将 c++ 框架与 iot 技术集成至关重要,以互操作 iot 设备。qt 和 boost.asio 等流行框架可用于连接 iot 设备:qt:跨平台应用程序框架,提供广泛的 ui 控件、网络和传感器支持。boost.asio:c++ 库,用于异步网络编程,提供高…

    2025年12月18日
    000
  • C++ 框架支持可扩展性的最佳实践是什么?

    在构建可扩展的 c++++ 应用程序时,选择支持可扩展性的框架至关重要。以下最佳实践可以实现可扩展性:运用分层架构将应用程序解耦为不同的层,实现不同层独立修改和扩展。使用依赖注入灵活切换实现,而无需修改代码逻辑。提供接口而非实现,抽象底层实现,便于轻松切换实现。 C++ 框架支持可扩展性的最佳实践 …

    2025年12月18日
    000
  • C++ 框架中内存管理的陷阱及应对措施

    c++++ 框架中内存管理的陷阱和应对措施:循环引用:互相引用的对象无法释放,使用智能指针解决。野指针:未初始化或已释放的指针,谨慎处理内存分配和检查返回值。二次释放:已释放对象指针再次释放,使用调试工具检测并重写代码。 C++ 框架中内存管理的陷阱及应对措施 背景 C++ 中手动管理内存容易出错,…

    2025年12月18日
    000
  • 在C++框架集成中使用第三方库的优缺点?

    第三方库在 c++++ 框架集成中的优缺点:优点:功能扩展:提供丰富功能,如数据库连接、图像处理或机器学习算法。代码重用:节省开发时间,减少返工。性能优化:针对特定任务性能优化。社区支持:提供支持、文档和示例。缺点:依赖性管理:版本、更新和兼容性问题。代码维护:第三方库维护责任不在框架团队。授权问题…

    2025年12月18日
    000
  • C++框架提供的错误处理机制有哪些

    c++++ 框架中的错误处理机制c++ 框架错误处理机制包括:异常机制:使用 try-catch 块捕获和处理异常。raii:使用资源获取即初始化技术自动管理资源。错误代码:使用整数值指示错误条件。 C++ 框架中的错误处理机制 在 C++ 中,使用框架来开发应用程序可以简化开发过程并提供稳健性。这…

    2025年12月18日
    000
  • 理解C++框架中的内存管理和垃圾回收

    c++++ 框架中提供内存管理机制(内存池和智能指针)以简化内存分配和释放。这些机制可自动释放不再使用的内存,例如对象超出作用域或引用计数为零时。智能指针(如 unique_ptr 和 shared_ptr)封装了原始指针,并负责自动释放所指向的内存。垃圾回收,通过引用计数等机制实现,可自动释放不再…

    2025年12月18日
    000
  • 如何调试 C++ 框架中的跨团队协作问题?

    要调试跨团队协作问题,需要:理解代码库结构。使用调试器逐步执行代码。设置日志记录机制。编写单元测试以隔离问题。采取实战案例,设置日志记录和测试以识别问题并向团队报告。 如何在 C++ 框架中调试跨团队协作问题 在大型 C++ 框架的开发中,多个团队通常协作处理不同的模块。这可能会导致复杂的跨团队协作…

    2025年12月18日
    000
  • 如何确保C++框架扩展的安全性?

    可通过以下步骤确保 c++++ 框架扩展的安全性:1. 验证用户输入;2. 使用安全的库;3. 限制访问敏感信息;4. 处理异常;5. 实施代码审查。通过遵循这些步骤,您可以确保扩展代码的安全性和框架的整体完整性。 如何在确保 C++ 框架扩展的安全性? 在扩展 C++ 框架时,确保安全性至关重要。…

    2025年12月18日
    000
  • C++ 框架中资源管理的最佳实践

    在 c++++ 框架中,资源管理包括有效管理系统资源,如内存、文件和网络连接。遵循以下最佳实践可实现高效的资源管理:优先使用 raii 惯用法,以在作用域结束后自动清除资源。使用智能指针来自动释放不再需要的资源。使用现代 c++ 管理容器,以获得更有效的内存管理。正确处理异常,以防止资源泄漏。使用库…

    2025年12月18日
    000
  • 不同类型 C++ 框架的最佳实践有什么差异?

    不同 c++++ 框架类型的最佳实践各不相同,具体取决于其设计理念和目标受众。web 框架遵循 mvc 架构、restful 设计和使用模板引擎,而测试框架使用单元测试、模拟和 bdd。orm 框架实现对象-关系映射,惰性加载和审计跟踪。di 框架采用依赖反转、配置文件和对象作用域管理依赖关系。 不…

    2025年12月18日
    000
  • 如何将C++框架与Java集成?

    如何将 c++++ 框架与 java 集成?可以通过以下方法集成:java native interface (jni):使用 c 语言接口访问 c++ 框架。jna (java native access):使用 java 库调用 c++ 类和函数。 如何将 C++ 框架与 Java 集成 前言 …

    2025年12月18日
    000
  • 使用C++框架需要注意哪些陷阱?

    使用 c++++ 框架时,需要注意内存泄漏、资源管理、线程安全和依赖性管理等陷阱。通过使用智能指针、raii 机制、包管理器和其他最佳实践,可以避免这些陷阱,开发健壮且可维护的应用程序。 使用 C++ 框架的陷阱 在使用 C++ 框架时,需要考虑一些潜在的陷阱,以确保代码的健壮性和可维护性。本文将讨…

    2025年12月18日
    000
  • C++框架中异常处理的性能开销及优化策略?

    异常处理会带来性能开销,主要原因包括内存分配、匹配 catch 块查找和栈展开。优化策略包括使用 noexcept 关键字、try/catch 代码块、避免嵌套 try/catch 块、采用 raii 原则和使用错误处理库。 C++ 框架中异常处理的性能开销及优化策略 引言异常处理是现代 C++ 编…

    2025年12月18日
    000
  • 哪种C++框架最适合用于云原生开发?

    最流行的 c++++ 云原生框架包括 envoy(服务网格)、grpc(rpc 框架)和 kubernetes(编排平台)。envoy 提供负载均衡、服务发现和 tls 加密;grpc 支持高效的网络通信;kubernetes 提供容器化应用程序的协调和编排。通过使用这些框架,企业可以在云平台上构建…

    2025年12月18日
    000
  • C++框架中的内存管理实践如何影响性能?

    有效的内存管理对c++++框架性能至关重要。关键实践包括:1. 智能指针以自动释放内存并防范泄漏;2. 优先栈分配以提高速度;3. 使用内存池以重用块提高效率;4. 减少内存片段以改善性能。不同实践影响性能的实战案例表明,栈分配(如list)的插入速度比堆分配(如vector)更快。 C++ 框架中…

    2025年12月18日
    000
  • C++框架的稳定性如何?

    c++++ 框架以其高稳定性而闻名,体现在以下方面:底层 c++ 语言提供健壮的类型安全和健壮的资源管理机制。框架利用 raii、异常处理和线程安全性等技术来增强稳定性。诸如 boost.asio 等框架在高流量服务器应用程序中得到验证,证明了其在并发性方面的稳定性。 C++ 框架的稳定性:探秘 R…

    2025年12月18日
    000
  • 哪种C++框架最适合开发跨平台Web应用程序?

    最佳 c++++ 跨平台 web 应用程序框架包括:qt:提供用户界面和应用程序开发功能。poco:包含网络编程、数据存储和并发编程库。libcurl:用于网络应用程序开发的低级 c 语言库,也可通过 c++ 使用。 最佳 C++ 跨平台 Web 应用程序框架 在当今快节奏的数字世界中,开发跨平台 …

    2025年12月18日
    000
  • 如何使用C++框架在Web应用程序中实现实时通信?

    使用 c++++ 框架实现实时通信时,选择一个合适的框架至关重要,例如 websocket++、boost.asio 或 pistache。使用 websocket++ 作为示例,服务器端设置监听地址和端口,并使用 on_message 处理程序接收和广播消息。客户端设置连接和消息处理程序,连接到服…

    2025年12月18日
    000
  • c++中::是什么

    C++ 中“::”是命名空间作用域运算符,它解决名称冲突并允许访问全局命名空间。具体步骤:解决命名空间内的名称冲突:使用“::”指定要使用的命名空间,以避免名称混乱。访问全局命名空间中的元素:通过“::”前缀,您可以访问未包含在任何命名空间中的元素。 C++ 中的“::”:命名空间作用域运算符 在 …

    2025年12月18日
    000
  • c++中::是什么意思

    C++ 中 :: 运算符是一个作用域解析运算符,用于指定名称空间、类或基类的范围。它有以下几种用法:名称空间解析::: 指明名称空间,如 my_namespace::my_variable。类静态成员访问::: 访问类的静态成员,如 MyClass::my_static_variable。基类解析:…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信