成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一篇文章帶你了解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關鍵字

2020-11-10 10:48:10

JavaScript屬性對象

2021-01-29 18:41:16

JavaScript函數語法

2021-06-04 09:56:01

JavaScript 前端switch

2021-02-02 18:39:05

JavaScript

2021-01-26 23:46:32

JavaScript數據結構前端

2023-07-30 15:18:54

JavaScript屬性

2021-05-18 08:30:42

JavaScript 前端JavaScript時

2021-03-09 14:04:01

JavaScriptCookie數據

2024-04-19 14:23:52

SwitchJavaScript開發

2021-06-24 09:05:08

JavaScript日期前端

2021-03-05 18:04:15

JavaScript循環代碼

2024-01-30 13:47:45

2023-09-06 14:57:46

JavaScript編程語言

2021-11-26 11:10:07

JavaScript 節點導航

2022-05-13 16:21:38

javascrip腳本SVG

2023-06-01 17:10:12

HTMLJavaScript

2023-06-06 15:45:40

JavaScript數組

2023-07-25 16:06:57

JavaScript對象
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线午夜 | 日韩在线免费播放 | 久久精品国产免费看久久精品 | 亚洲日本一区二区三区四区 | 一区二区三区精品视频 | 人人干免费 | 国产高清在线精品 | 日韩欧美一二三区 | 亚洲二区在线 | 欧美一区二区三区国产精品 | 色婷婷综合网 | 天堂av影院 | 天堂资源最新在线 | 国产日韩精品视频 | 日本网站免费观看 | 日韩最新网站 | 久久精品91久久久久久再现 | 欧美日韩一区精品 | 亚洲国产精品视频一区 | 男人天堂网址 | 亚洲va在线va天堂va狼色在线 | 亚洲va欧美va人人爽午夜 | 亚洲电影一区二区三区 | 特一级毛片| www.玖玖玖 | 免费日本视频 | 久久日韩粉嫩一区二区三区 | 日韩欧美三级电影在线观看 | 中文字幕精品一区 | 91精品一区二区三区久久久久 | 99热播精品| 亚洲a在线观看 | 九九热在线视频免费观看 | 欧美理论在线观看 | 国产精品一区一区三区 | 亚洲成人久久久 | 亚洲人在线播放 | 日韩久久久一区二区 | 91高清在线观看 | 久久久久国产 | 综合另类|