JavaScript中this指向什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
創新互聯是一家集網站建設,榆陽企業網站建設,榆陽品牌網站建設,網站定制,榆陽網站建設報價,網絡營銷,網絡優化,榆陽網站推廣為一體的創新建站企業,幫助傳統企業提升企業形象加強企業競爭力??沙浞譂M足這一群體相比中小企業更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們為更多的企業打造出實用型網站。它代表函數運行時,自動生成的一個內部對象,只能在函數內部使用。隨著函數使用場合的不同,this的值會發生變化。但是有一個總的原則,那就是this的指向在函數定義的時候是確定不了的,只有函數執行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調用它所在函數的對象。 那么接下來我們一步步探索下這個問題。
function a() { var user = "清蒸胖頭魚"; console.log(this.name); //undefined console.log(this); //Window } a(); window.a();//兩種結果相同
如我們上文所說的this的最終指向的是那個調用它所在函數的對象,這里a其實是由window對象點出來的。
var obj = { name: '清蒸胖頭魚', f1: function () { console.log(this.name);//清蒸胖頭魚 } }; obj.f1();
再次強調一點this的指向在函數定義的時候是確定不了的,只有函數執行的時候才能確定this到底指向誰;這個例子this所在的f1函數是由obj對象調用的,所以這里的this指向obj對象。
如果要徹底的搞懂this必須看接下來的幾個例子
var obj = { a: 5, b: { a: 10, fn: function () { console.log(this.a); //10 } } }; obj.b.fn();
不是說this的最終指向的是那個調用它所在函數的對象嗎?這里為什么不指向obj對象呢?
這里需要補充三點:
如果一個函數中有this,但是它沒有被上一級的對象所調用,那么this指向的就是window。
如果一個函數中有this,這個函數有被上一級的對象所調用,那么this指向的就是上一級的對象。
如果一個函數中有this,這個函數中包含多個對象,盡管這個函數是被最外層的對象所調用,this指向的也只是它上一級的對象。
看到這相信大家基本掌握了this指向的原則了吧,再碎碎念一遍:this的指向在函數定義的時候是確定不了的,只有函數執行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調用它所在函數的對象。
構造函數(new 關鍵字)情況
function Student() { this.name = '清蒸胖頭魚'; } var s1 = new Student(); console.log(s1.name);// 清蒸胖頭魚
這里之所以對象s1可以點出函數Student里面的name 是因為new關鍵字可以改變this的指向,將這個this指向對象s1.
// new 關鍵字執行的過程 1. 在函數體內創建一個空的對象. 2. 讓當前this指向這個空的對象. 3. 通過this給當前空的對象添加鍵值對. 4. 返回已經添加好所有鍵值對的對象給外面的變量.
定時器里的this指向情況
var num = 0; function Obj() { this.num = 1; this.getNum1 = function () { console.log(this.num); }; this.getNum2 = function () { setInterval(function () { console.log(this.num); }, 1000); }; } var o = new Obj(); o.getNum1();//1 (o.num) o.getNum2();//0 (window.num)
o.getNum2()
值之所以為0,也就是這里的this
指向window
,再拿出我們的this指向原則解釋:this
的指向在函數定義的時候是確定不了的,只有函數執行的時候才能確定this
到底指向誰,實際上this
的最終指向的是那個調用它所在函數的對象。
解:this.num
所在的函數為定時器setInterval
內的function () { console.log(this.num);}
,根據this指向原則當該函數被執行,this指向它的上一級對象。setInterval
,又因setInterval
是window
點出了的,所以this
指向window
。
call
、apply
、bind
改變指向情況
var num = 0; function Obj() { this.num = 1; this.getNum1 = function () { console.log(this.num); }; this.getNum2 = function () { setInterval(function () { console.log(this.num); }.bind(this), 1000);//利用bind將this綁定到這個函數上 }; } var o = new Obj(); o.getNum1();//1 (o.num) o.getNum2();//1 (o.num)
解釋:
bind()方法是Function.prototype上的一個方法,當被綁定函數調用時,bind方法會創建一個新函數,并將第一個參數作為新函數的運行時的this。
根據原則:
沒使用bind
方法前:被調用時:this.num
指向的是調用它所在函數的對象,也就是window.setTimeout
對象。 使用bind
方法后:被調用時:將原來的this
重新指向到→調用getSum2
函數(就是新this
所在的函數)的對象。這里構造函數,通過new
調用,所以指向o對象。
bind
方法在該情況比較常用,當然如果使用call
或apply
方法來代替也行,得到的結果也是正確的,但是call
和apply
方法會在調用后馬上執行,那樣就沒了延時的效果,定時器也就沒有意義了。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創新互聯行業資訊頻道,感謝您對創新互聯網站建設公司,的支持。
名稱欄目:JavaScript中this指向什么-創新互聯
標題鏈接:http://m.newbst.com/article44/dcgiee.html
成都網站建設公司_創新互聯,為您提供標簽優化、品牌網站設計、網站設計公司、企業網站制作、網站策劃、電子商務
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯