JavaScript中的this引用(推薦)_javascript技巧

來源:互聯網
上載者:User

this

this是javascript的一個關鍵字,隨著函數使用場合不同,this的值會發生變化。但是總有一個原則,那就是this指的是調用函數的那個對象。

一、定義

1、this是函數內部的一個特殊對象(或this引用)--它引用的是函資料以執行的環境對象。

2、this引用是一種在JavaScript的代碼中隨時都可以使用的唯讀變數。 this引用 引用(指向)的是一個對象,它有著會根據代碼上下文語境自動改變其引用對象的特性。它的引用規則如下:

• 在最外層代碼中,this引用 引用的是全域對象。

• 在函數內,this引用根據函數調用的方式的不同而有所不同。如下

1)建構函式的調用--this引用 引用的是所產生的對象

2)方法調用--this引用 引用的是接收方對象

3)apply或call調用--this引用 引用的是有apply或call的參數指定的對象

4)其他方式的調用--this引用 引用的是全域對象

二、根據以上所述及網上的相關資料,this對象(引用)的使用方式總結如下:

JavaScript是動態語言,this關鍵字在執行的時候才能確定是誰。所以this永遠指向調用者,即對“調用對象”的引用。簡單點說就是調用的方法屬於哪個對象,this就指向那個對象。根據函數調用方式的不同,this可以 指向全域對象,當前對象,或其他任意對象。

1、全域函數調用,全域函數中的this會指向全域對象window。(函數調用模式)

//代碼清單1<script type="text/javascript">var message = "this in window"; //這一句寫在函數外面和裡面是一樣效果function func() {if(this == window){alert("this == window"); alert(message);this.methodA = function() {alert("I'm a function");}}}func(); //如果不調用func方法,則裡面定義的屬性或方法會取不到 methodA();</script>

func()的調用結果為this == window, this in window

methodA()的調用結果為I'm a function

2、建構函式調用,即使用new的方式執行個體化一個對象,this會指向通過建構函式產生的對象。(構造器調用模式)

代碼清單2

<script type="text/javascript">function Func() {if (this == window) {alert("this == window");}else {alert("this != window");}this.fieldA = "I'm a field";alert(this);}var obj = new Func();alert(obj.fieldA); //this指向的是對象obj</script>

3、對象方法的調用,this指向當前對象。任何函數,只要該函數被當做一個對象的方法使用或賦值時,該函數內部的this都是對該對象本身的引用。也可理解為this寫在一個普通對象中,this指向的就是對象本身。(方法調用模式)

(方法的定義: 作為對象屬性的函數稱為方法)

//代碼清單3<script type="text/javascript">var obj = {x: 3,doit: function(){if(this == window){alert("this == window");}else{alert("method is called: " + this.x);}}};obj.doit(); //this指向的是對象obj</script>

4、通過apply或call方法調用,this指向傳入的對象。

apply 或call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的物件內容從初始的上下文改變為由 thisObj 指定的新對象。如果沒有提供 thisObj 參數,那麼 Global 對象被用作 thisObj。 (apply調用模式)

//代碼清單4<script type="text/javascript">var obj = {x: 3,doit: function(){alert("method is called: " + this.x);}};var obj2 = {x: 4};obj.doit(); //3,this指向objobj.doit.apply(obj2); //4,this指向obj2obj.doit.call(obj2); //4,this指向obj2</script>

5、原型鏈中的this --原型對象及建構函式中的this指向新建立的執行個體對象。使用prototype擴充方法可以使用this擷取到來源物件的執行個體,私人欄位無法通過原型鏈擷取。

//代碼清單5<script type="text/javascript">function Func() {this.fieldA = "I'm a field";var privateFieldA = "I'm a var";}Func.prototype = {ExtendMethod: function(str) {alert(str + " :" + this.fieldA);alert(privateFieldA); //出錯,私人欄位無法通過原型鏈擷取。}};var obj = new Func();obj.ExtendMethod("From prototype"); //此時建構函式及原型鏈中的this指向對象obj</script>

6、閉包中的this --閉包:寫在function中的function,this指向全域對象window。

6.1 對象中的閉包

//代碼清單6<script type="text/javascript">var name = "The window";var obj = {name: "My Object",getNameFunc: function(){return function(){return this.name;}}};alert(obj.getNameFunc()()); //The window</script>

此時,閉包中的this指向全域對象window,只能取到全域對象的屬性。那麼對象內部的屬性(外部函數的變數)要想訪問又怎麼辦呢? 把外部函數的this對象儲存在一個閉包能訪問的變數就可以了。看如下代碼:

//代碼清單7<script type="text/javascript">var name = "The window";var obj = {name: "My Object",getNameFunc: function(){var that = this;return function(){return that.name;}}};alert(obj.getNameFunc()()); //My object</script>

將外部函數的this賦值給that變數,就能讀取到外部函數的變數。

6.2 不管是直接引用function,還是執行個體化一個function,其返回的閉包函數裡的this都是指向window。

//代碼清單8<script type="text/javascript">function a() {alert(this == window);var that = this;var func = function() {alert(this == window);alert(that);};return func;}var b = a();b(); //true, true, [object Window]var c = new a();c(); //false, true, [object object]</script>

7、函數使用bind()方法綁定一個對象,this會指向傳給bind()函數的值。

//代碼清單9<script type="text/javascript">window.color = "red";var obj = {color: "blue"};function sayColor(){alert(this.color);}var objSayColor = sayColor.bind(obj);objSayColor(); //blue</script>

8、內嵌在HTML元素中的指令碼段,this指向元素本身

//代碼清單10<div onclick="test(this)" id="div">Click Me</div><script type="text/javascript">function test(obj) {alert(obj); //[object HTMLDivElement]}</script>

9、寫在script標籤中:this就是指全域對象window。這個跟第一點的全域函數調用的全域變數一樣。

以上所述是小編給大家介紹的JavaScript中的this引用,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.