您好,登錄后才能下訂單哦!
這篇文章主要介紹JavaScript中this是什么,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
記得初學 JavaScript 時,其中 this 的指向問題曾讓我頭疼不已,我還曾私自將其與閉包、原型(原型鏈)并稱 JS 武林中的三大魔頭。如果你要想在 JS 武林中稱霸一方,必須將這三大魔頭擊倒。個人認為在這三大魔頭中,this 指向問題的武功最菜(難度最低)。俗話說柿子撿軟的捏,那我們就先從 this 指向問題下手。
先記住攻克 this 指向問題的口訣(前輩們的總結):哪個對象調用函數,函數里的 this 就默認指向哪個對象(注意 this 只能指向對象)。這里說“默認指向”是因為我們通過箭頭函數、call、apply、bind等手段來改變 this 的指向。現在我們只討論 this 的默認指向。
全局作用域下以及全局作用域的函數中,this默認指向全局對象window
在嚴格模式下,全局作用域的函數中,this默認指向 undefined, 這是嚴格模式所規定的。
// 非嚴格模式下 console.log(this); // Window function doSomething(){ console.log(this); // Window } doSomething(); // 這里可以看成window.doSomething(),所以函數里的this指向全局對象window // 嚴格模式下 'use strict'; console.log(this); // Window function doInStrict(){ console.log(this); // undefined } doInStrict();
對象里的函數,this指向該對象
var a = 1; var obj = { a: 2, fn: function(){ console.log(this); // {a: 2, fn: ƒ} console.log(this.a); // 2 } }; obj.fn();
上面函數被調用后,從打印結果可以看出此時 this 指向的是調用函數的對象 obj。如果將對象中的函數賦給全局對象中定義的變量 fn1,執行 fn1 又會出現什么結果呢?
var a = 1; var obj = { a: 2, fn: function(){ console.log(this); // Winidow console.log(this.a); // 1 } }; var fn1 = obj.fn; fn1(); // 可以看成window.fn1();
從上面的例子可以看出,fn1 與 obj.fn 指向的函數是相同的,但是調用它的對象不同,那么函數中 this 的指向也就不一樣了。
再看一個比較復雜的例子:
var a = 0; function fn(){ consoloe.log(this.a); } var obj1 = { a: 1, fn: function(){ console.log(this.a); } }; var obj2 = { a: 2, fn: function(){ fn(); obj1.fn(); console.log(this.a); } } obj2.fn();
先說下執行結果,分別打印 0 1 2。當 obj2 調用 fn 函數時,先執行的是 fn(),這個函數是在全局作用域中定義的,該調用可以看成 window.fn(),所以,該函數內部的 this 指向的是 window 全局對象,this.a 自然就是全局對象中的 a 值(0)。
接著執行的是 obj1.fn(),它會從 obj1 中找到 fn 函數并執行。obj1 中的函數 fn 執行時調用它的對象是 obj1,所以,此時函數內部的 this 指向的就是 obj1 自身。那么 this.a 查到的值也就是對象 obj1 中 a 的值(1)。
最后打印函數中 this 所處的函數 fn 是被 obj2 調用的,那么自然而然 this 就指向了 obj2,所以 this.a 的結果就是 2 了。
從上面這個例子我們可以看出:函數內部 this 指向跟調用函數的對象有關,跟函數在哪里調用沒有關系。
Window內置函數的回調函數中,this指向Window對象。
window 的內置函數( setInterval setTimeout 等),其回調函數中的 this 指向的是window對象。
var name = 'window'; var obj = { name: 'obj', func: function(){ setTimeout(function () { console.log(this.name) // window },1000) } } obj.func()
但是一般在開發中,很多場景都需要改變 this 的指向。 后面我會專門寫一篇關于更改 this 指向的文章,這里就不再贅述了。
以上是JavaScript中this是什么的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。