一篇文章带你了解JavaScript this关键字

开发 前端
与其他语言相比,this关键字在JavaScript中的行为略有不同。JavaScript中,this关键字引用其所属的对象。根据使用位置,它具有不同的值。

[[395233]]

与其他语言相比,this关键字在JavaScript中的行为略有不同。JavaScript中,this关键字引用其所属的对象。根据使用位置,它具有不同的值。

一、前言

方法中,this关键字引用其所属的对象。

this指的是全局对象在函数中。

this引用全局对象在函数中。

在严格模式下,this是未定义的在事件中。

this指的是接收事件的元素像call()和apply()这样的方法,可以将其引用到任何对象。

二、方法上下文

在对象方法中,this指代方法的user。

当调用user.getName()时,函数内部将this绑定到user对象:

例:

  1. <!DOCTYPE html> 
  2. <html> 
  3. <title>项目</title> 
  4.  
  5. <body style="background-color: aqua;"
  6.  
  7. <p>在此示例中,<b> user </b>对象是<b> getName </b>方法的所有者:</p> 
  8.  
  9. <script> 
  10. // 创建一个对象 
  11. var user = { 
  12. firstName: "基础教程"
  13. lastName: "baidu.com"
  14. age: 5, 
  15. getName: function() { 
  16. return this.firstName + " " + this.lastName; 
  17. }; 
  18.  
  19. document.write(user.getName()); 
  20. </script> 
  21.  
  22. </body> 
  23. </html> 

这里user对象是所有者getName的方法。

1. 全局上下文

在全局执行上下文中(在任何函数之外),this无论是否处于严格模式下,都引用全局对象。

示例

  1. <!DOCTYPE html> 
  2. <html> 
  3. <title>项目</title> 
  4.  
  5. <body style="background-color: aqua;">  
  6.  
  7. <p>在全局执行上下文中(在任何函数之外),这指的是全局对象:</p> 
  8.  
  9. <p>访问调试在您的浏览器按F12,并选择"控制台"在调试器菜单:</p> 
  10.  
  11. <script> 
  12. //在Web浏览器中,窗口对象也是全局对象: 
  13. console.log(this === window); // true 
  14.  
  15. a = 50; 
  16. console.log(window.a); // 50 
  17.  
  18. this.b = "baidu.com"
  19. console.log(window.b) // "nhooo.com" 
  20. console.log(b) // "nhooo.com" 
  21. </script> 
  22.  
  23. </body> 
  24. </html> 

在浏览器窗口中,全局对象是[object Window]。

2. 函数上下文

在函数内部,this值取决于函数的调用方式。由于以下代码不在严格模式下,this因此默认为全局对象,即浏览器中的[object Window]。

  1. function myFunc() { 
  2. return this; 

在严格模式,然而this的值是undefined。

  1. function myFunc() { 
  2. "use strict"
  3. return this; 

因此,在严格模式下,如果执行上下文未定义它,则它将保持未定义状态。

三、this在DOM事件处理程序中

当一个函数用作事件处理程序时,this将被设置为触发事件的元素:

示例

  1. let btn = document.querySelector("button"); 
  2.  
  3. btn.onclick = function() { 
  4. this.style.display = "none"
  5. }; 

从内联事件处理程序调用代码时,会将this设置为放置监听器的元素:

  1. <button onclick="this.style.display='none'">点击删除我</button> 

四、显式函数绑定

call()和apply()方法是预定义的JavaScript方法。

它们都可以用于调用以另一个对象作为参数的对象方法。

  1. <script> 
  2. function add(c, d) { 
  3. return this.a + this.b + c + d; 
  4.  
  5. var obj = { 
  6. a: 5, 
  7. b: 10 
  8. }; 
  9.  
  10. //第一个参数是用作 
  11. //'this',后续参数作为 
  12. //函数调用中的参数 
  13. document.writeln(add.call(obj, 5, 7)); // 27 
  14.  
  15. //第一个参数是要使用的对象 
  16. // 'this',第二个是一个数组 
  17. //成员用作函数调用中的参数 
  18. document.writeln(add.apply(obj, [10, 20])); // 45 
  19. </script> 

箭头函数(=>)

在箭头函数(=>)中,this始终指向它被创建时所处的词法作用域中的this。全局代码中,它将被设置为全局对象:

  1. <script> 
  2. var globalObj = this; 
  3. var myFunc = (() => this); 
  4.  
  5. document.write(myFunc() === globalObj);// true 
  6. </script> 

五、总结

本文基于JavaScript 基础,介绍了this 关键字,与其他语言相比,this关键字在JavaScript中的行为略有不同,对this ,包括(全局,函数,函数绑定)常见的用法进行了详细的讲解。希望能够通过文章的学习,让读者更好的认识,学习JavaScript。

 

 

责任编辑:武晓燕 来源: 前端进阶学习交流
相关推荐

2020-12-28 13:22:47

单例模式关键字

2020-12-29 05:31:33

单例模式this关键字

2021-01-29 18:41:16

JavaScript函数语法

2021-06-04 09:56:01

JavaScript 前端switch

2020-11-10 10:48:10

JavaScript属性对象

2021-02-02 18:39:05

JavaScript

2023-09-06 14:57:46

JavaScript编程语言

2021-05-18 08:30:42

JavaScript 前端JavaScript时

2023-07-30 15:18:54

JavaScript属性

2021-01-26 23:46:32

JavaScript数据结构前端

2021-03-05 18:04:15

JavaScript循环代码

2024-01-30 13:47:45

2021-03-09 14:04:01

JavaScriptCookie数据

2021-06-24 09:05:08

JavaScript日期前端

2024-04-19 14:23:52

SwitchJavaScript开发

2023-06-06 15:45:40

JavaScript数组

2021-11-26 11:10:07

JavaScript 节点导航

2021-04-20 11:20:24

Java开发运算符

2023-07-25 16:06:57

JavaScript对象

2023-08-27 15:18:17

JavaScriptRegExp
点赞
收藏

51CTO技术栈公众号