Javascript------this的奧秘

来源:http://www.cnblogs.com/CDXwangwang/archive/2016/12/09/6151475.html
-Advertisement-
Play Games

Javascript 之探索this的奧秘 前言: this 是 JavaScript 比較特殊的關鍵字,運用的地方之廣,方式之靈活奠定了它的強大,但同時註定了它的難用 。自己剛開始學的時候被繞的很暈,為了徹底弄懂它查了很多資料。然後將自己學的東西整理了一下,以通俗易懂的方式表達出來,權當做學習筆記 ...


Javascript 之探索this的奧秘

前言: this 是 JavaScript 比較特殊的關鍵字,運用的地方之廣,方式之靈活奠定了它的強大,但同時註定了它的難用 。自己剛開始學的時候被繞的很暈,為了徹底弄懂它查了很多資料。然後將自己學的東西整理了一下,以通俗易懂的方式表達出來,權當做學習筆記,同時也可以給有需要的童鞋做下參考^_^

什麼是this?

   this 關鍵字的含義是明確且具體的,即指代當前對象。即意味著這個 this 是在某種相對情況下才成立的。

   this 被分為三種情況:全局對象、當前對象或者任意對象;判斷處於那種情況,這完全取決於函數的調用方式,JavaScript 中主要的函數調用有以下幾種方式:

  • 作為普通函數調用
  • 作為對象方法調用
  • 作為構造函數調用
  • 使用 apply 或 call 調用

1. 作為普通函數調用

------這是我們最常用的方法,這種調用方式屬於全局調用,這裡的 this 指的是全局對象

function test(){
    this.a = 5;
    alert(this.a);
    alert(this);
}
test(); // 5  [object Window]

   如上所示:定義在全局的函數, 函數的所有者就是當前頁面, 也就是window對象,所以example()的調用對象就是Window,因此這裡面的this就代表Window;

 換一種寫法:

 

var a = 5;
function test(){
    var a = 10;
    alert(this.a);
}
test(); //5

   如上所示:test()函數內部也聲明瞭一個變數a,但是調用test()的結果為5,說明此時函數內部的this代表了全局對象即Window;

   再換種寫法:

 

var a = 5;
function test(){
    this.a = 10;
}
test();
alert(a); //10

  如上所示: 調用test()函數,更改了全局變數a的值,即表明此時this代表全局對象。

 

2.作為對象函數的調用

------當函數被某個對象調用時,此時this就指向了這個對象

    var name="張三";
  var person={
      name:"李四",
      showName:function(){
          alert(this.name);
      }
  }

  person.showName();  //輸出  李四
 
    var other=person.showName;

  other();    //輸出  張三

如上所示:執行 person.showName()的結果為 李四,說明此時showName中的this指向了person;

而把person.showName賦給other後,因為other屬於全局變數,可以看成是window對象的一個屬性。所以當調用other(),相當於調用window.other(),因此this指向了window, 輸出結果為 張三;

所以說作為函數對象調用時,this就指向了這個調用的對象。

 

3. 作為構造函數調用

------構造函數,就是通過這個函數生成一個新對象(object),這時候的 this 就會指向這個新對象;

function animal(){

    this.name = "豆豆";
}

var dog = new animal();

alert(dog.name); // 輸出 豆豆

如上所示:通過new關鍵字生成一個object類型的對象並把它賦給dog,執行這個構造函數的話,會吧構造函數作用域里的this指向這個對象,在這裡就是指向了dog,因此this.name 等同於dog.name, 所以輸出結果為豆豆。

 

4.使用 apply 或 call 調用

------apply()是函數對象的一個方法,它應用某一對象的一個方法,用另一個對象替換當前對象。

var a = "張三";
function test(){
    alert(this.a);
}
var b = {};
b.a = "李四";
b.n = test;
b.n();  //李四
b.n.apply();  //張三
b.n.apply(b);  //李四

如上所示:b.n()----因為調用的對象為b,所以this指向了b,this.a  == b.a  ,所以結果為李四;

     b.n.apply----當apply()的參數為空時,就是沒有對象去替換當前對象,預設用全局對象,所以this指向window,結果為張三;

     b.n.apply(b)----指將當前的this指向替換成b,因此this指向了b,結果為李四

 

(本文參考了網上的資料和一些書籍,如有錯誤之處,歡迎指出,將及時改正,麽麽噠O(∩_∩)O)

總結:本文介紹了 JavaScript 中的 this 關鍵字在各種情況下的含義,實例都很簡單,這樣更能有助於加深理解。雖然這隻是 JavaScript 中一個很小的概念,但藉此我們可以瞭解 JavaScript 中函數的執行環境,充分掌握this的相關知識有助於我們在編寫面向對象的JavaScript程式時能夠游刃有餘。最後,感謝您的觀看。

 

後記------以前寫的博客內容有點亂,所以全給刪了,決定以後好好寫,會將學到的知識記錄在博客中,方便你我他。。有興趣的小伙伴可以一塊多多交流,共同進步O(∩_∩)O

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1,super關鍵字 super:父類的意思 1. super.屬性名 (調用父類的屬性) 2. super.方法名 (調用父類的方法) 3. super([參數列表])(調用父類的構造方法) 註意:a. super關鍵字使用在子類中 b. 子類繼承了父類,則父類中的公有的屬性,方法,就是子類的屬性 ...
  • 最近在做電商業務中,有關商品業務改版的一些東西,後端的架構設計採用現在很流行的微服務,有關微服務的簡單概念: 微服務是一種架構風格,一個大型複雜軟體應用由一個或多個微服務組成。系統中的各個微服務可被獨立部署,各個微服務之間是松耦合的。每個微服務僅關註於完成一件任務並很好地完成該任務。在所有情況下,每 ...
  • 最近開始重構一個稍嫌古老的C/S項目,原先採用的技術棧是『WinForm』+『WCF』+『EF』。相對於現在鋪天蓋地的B/S架構來說,看上去似乎和Win95一樣古老,很多新入行的,可能就沒有見過經典的C/S架構的系統。事實上,作為企業信息管理系統,包括ERP/CRM/SCM等,桌面客戶端還是很OK的 ...
  • 記憶體泄露與垃圾回收機制。 1)、記憶體泄露 由於堆中的對象(數據)創建過多, 導致堆中無法存儲,於是出現了記憶體泄露現象。 此現象非常可怕,後果非常嚴重。需杜絕。 記憶體中存儲的數據為臨時數據,臨時數據使用之後, 要及時清理,使用之後的數據,就變成了“垃圾數據”, Java有對獨立運行的線程,可以實現不定 ...
  • 一、陰影 1.1、文字陰影 text-shadow<length>①: 第1個長度值用來設置對象的陰影水平偏移值。可以為負值 <length>②: 第2個長度值用來設置對象的陰影垂直偏移值。可以為負值 <length>③: 如果提供了第3個長度值則用來設置對象的陰影模糊值。不允許負值 <color> ...
  • 用原生的javascript實現方格拼圖效果 1.新建文件夾 代碼如下: 01.html 01.js 01.css 圖片 遇到一個問題: 在js代碼中的第9行和第10行,本來是一條語句,但我直接用鍵盤迴車把它們分成兩行時,會出現錯誤: 錯誤:syntaxerror:未結束的字元串。 Google之後 ...
  • 一、web font web font是應用在web中的一種字體技術,在CSS中使用font-face定義新的字體。先瞭解操作系統中的字體: a)、安裝好操作系統後,會預設安裝一些字體,這些字體文件描述了每一個文字的形態,一般中文文件大,英文文件小,因為中文字元數多;在控制面板中可以找到文字文件夾, ...
  • img標簽使用絕對路徑無法顯示圖片? 如果這張圖片屬於伺服器圖片或者網路圖片,我們必須在Img標簽里使用網路路徑,只有網路路徑才可以通過瀏覽器發送請求,下載該圖片到用戶的瀏覽器臨時路徑中,才可以顯示在頁面上; 如果這樣圖片在你本地,那麼你可以直接使用該圖片的磁碟路徑展示。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...