91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript This指向問題詳解

發布時間:2020-09-02 09:27:03 來源:腳本之家 閱讀:169 作者:Peerless1029 欄目:web開發

這篇文章主要介紹了JavaScript This指向問題詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

各位小伙伴在面試中被面試官問道this指向問題一定不少吧,同時還被問道apply,call和bind的用法區別,現在,就來簡單的聊一聊this到底指向何方。

1.基本概念

MDN的官方解釋:與其他語言相比,函數的 this 關鍵字在 JavaScript 中的表現略有不同,此外,在嚴格模式和非嚴格模式之間也會有一些差別。在絕大多數情況下,函數的調用方式決定了this的值。this不能在執行期間被賦值,并且在每次函數被調用時this的值也可能會不同。

簡而言之:

1.this指向的對象稱為函數的上下文對象context;  

2.this的指向取決于函數被調用方式

不管函數怎么調用的天花亂墜,我們只要記住這幾點即可清晰的找出this的指向。

2.小試牛刀

function foo(){
 console.log(this);
}

面試官問你this指向哪里,當然大聲回答不知道,原因:誰調用指向誰,函數都沒被調用,確實不知道指向。

JavaScript This指向問題詳解

小結:直接通過函數名來調用函數,this指向全局變量window;通過對象.函數名調用函數,this指向該對象。

3.DOM對象調用函數時this的指向問題

1.通過選擇器選擇元素加事件屬性來綁定事件,this指向該DOM對象,例子如下:

document.getElementById('btn').onclick=function(){
  console.log('click'); //click
  console.log(this); //<button id="btn">button</button>
 }

2.直接在DOM標簽中寫事件,this指向window,我們可以通過吧this作為參數傳入方法中再使用,例子如下

html:
<button onclick="modify()">add</button>
<span id="count">0</span>
<button onclick="modify()">reduce</button>

script:
// 操作方法
 function modify(){
  console.log(this); //window
 }

因為這個時候是直接調用方法的,所以this指向全局window對象,那么問題來了,我們想判斷我們點擊的是哪一個按鈕,應該怎么做呢,我們可以把this的值作為參數傳入方法中再使用,例子如下。

html:
<button onclick="modify(this)">add</button>
<span id="count">0</span>
<button onclick="modify(this)">reduce</button>

script:
// 操作方法
 function modify(_this){
  console.log(_this); 
// <button onclick="modify(this)">add</button>
// <button onclick="modify(this)">reduce</button>
 }

4.對象中this的指向問題

先看一個簡單的例子:

var a=1;
function printA(){
 console.log(this.a);
}
var obj={
 a:2,
 foo:printA,
 bar:function(){
  printA();
 }
}
obj.foo(); //2
obj.bar(); //1var foo=obj.foo;foo(); //1

我們定義了一個全局變量a和一個打印a的全局變量方法,之后又定義了一個obj對象,其中包含a屬性和foo,bar兩個方法。當我們調用obj.foo()打印了2,調用obj.bar()打印了1.

分析:

不管printA在哪里定義的,我們this的指向只取決于被誰調用的。在obj.foo(),foo的屬性值為printA,被obj直接調用,所以this指向obj,this.a就是obj.a=2了;

當我們調用obj.bar()時,bar的屬性值為function(){printA()},沒有明確哪個對象來調用printA方法,this默認指向全局對象window,所以this.a=window.a=1;

第三種情況我們把obj.foo值賦予了foo變量,在調用的時候就相當于是window.foo()了,打印1。

小結:this的指向不是函數聲明是綁定的,而是在函數運行過程中動態綁定的。

5.改變this的指向方法:applay call bind

話不多話:寫了一個例子,大家先看,萬一比喻不恰當,大家能理解其中意思即可

var liLei={
 name:'liLei',
 money:10,
 buyPen:function(){
  this.money=this.money-1;
  console.log(this.name+" have money:"+this.money)
 }
}

var hanMeiMei={
 name:'hanMeiMei',
 money:20,
 buyPan:function(){
  this.money=this.money-2;
  console.log(this.name+" have money:"+this.money)
 }
}

liLei.buyPen(); // liLei have money:9
hanMeiMei.buyPan(); //hanMeiMei have money:18

例子很好理解,輸出的結果相信大家也能看得明白,哪天,韓梅梅想買一個盆,她買不了,因為她還沒有這個方法,她一想:我沒有這個方法,但是李雷有啊,我打電話給李雷把錢他讓他幫我買啊;后來李雷想買一個盤,實現方法也是如此。那么,在代碼中如何實現呢?

JavaScript有好幾個方法可以實現:call,apply,bind。

call方法:

語法:call(thisObj,Object)

定義:調用一個對象的一個方法,以另一個對象替換當前對象。

說明:

call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj。

liLei.buyPen.call(hanMeiMei); //hanMeiMei have money:19
hanMeiMei.buyPan.call(liLei); //liLei have money:8

apply方法:

語法:apply(thisObj,[argArray])

定義:應用某一對象的一個方法,用另一個對象替換當前對象。

說明:

如果 argArray 不是一個有效的數組或者不是 arguments 對象,那么將導致一個 TypeError。如果沒有提供 argArray 和 thisObj 任何一個參數,那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數。

liLei.buyPen.apply(hanMeiMei); //hanMeiMei have money:19
hanMeiMei.buyPan.apply(liLei); //liLei have money:8

bind方法:

liLei.buyPen.bind(hanMeiMei)(); //hanMeiMei have money:19
hanMeiMei.buyPan.apply(liLei)(); //liLei have money:8

小結:三種方法的相同指出是:可以改變this的指向,不同之處是:apply接受的參數為一個數組,call接收的參數為一個個獨立的值;apply,call會直接調用方法,bind改變this的指向返回一個方法不調用。

注:有些低版本的瀏覽器不支持函數使用bind方法,我們在做瀏覽器兼容時可以加以判斷,具體實現方法暫不贅述。

以上就是個人對于this的指向問題的理解,我們只需記住一點:this指向-誰調用,指向誰。不得不說JavaScript真是個奇妙的世界,文中有紕漏不足的地方,歡迎指正。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

钟祥市| 沙湾县| 客服| 沾益县| 肥乡县| 桃园县| 平陆县| 新宾| 长武县| 石城县| 南木林县| 夏津县| 宝鸡市| 建昌县| 宁国市| 山西省| 崇阳县| 叙永县| 明星| 体育| 宝清县| 南靖县| 庆元县| 长阳| 凤翔县| 青川县| 金昌市| 蒙阴县| 历史| 洱源县| 洛隆县| 古丈县| 鄱阳县| 双鸭山市| 门源| 固安县| 贵阳市| 祁阳县| 宁陕县| 内丘县| 海阳市|