成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

詳解JavaScript中的this指向問題

瀏覽:104日期:2023-10-04 15:41:01
題記

JS中的this指向一直是個讓初學者頭疼的問題。今天,我們就一起來瞅瞅this倒地是咋回事,詳細說說this指向原則,從此不再為了this指向操碎了心。

開篇

首先我們都知道this是Javascript語言的一個關鍵字。

它代表函數運行時,自動生成的一個內部對象,只能在函數內部使用。隨著函數使用場合的不同,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的最終指向的是那個調用它所在函數的對象。

下面給大家介紹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指向問題的詳細內容,更多關于JavaScript this指向的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 99精品免费观看 | 免费一级毛片在级播放 | 日本人在线看片 | 成年网站免费 | 久久香蕉国产观看猫咪3atv | 国产精品blacked在线 | 欧美一级特黄特黄做受 | 黄男人和女人色一级 | 欧美黄视频在线观看 | 91成人在线免费视频 | 私人午夜影院 | 亚洲国产精品日韩在线观看 | 国产盗摄精品一区二区三区 | 国产上床视频 | 欧美另类专区 | 高清一级片 | 国产国语对白一级毛片 | 亚洲国产二区三区久久 | 亚洲第一页在线播放 | 亚洲第一在线 | 国产特黄特色的大片观看免费视频 | 成人毛片免费在线观看 | 中文字幕国产一区 | 制服丝袜在线视频香蕉 | 国产精品久久久久影院 | 久久国产精品最新一区 | 综合欧美日韩一区二区三区 | 国产精品毛片一区二区三区 | 特级毛片全部免费播放器 | 国产短视频精品一区二区三区 | 精品国产一区二区三区国产馆 | 国内精品视频成人一区二区 | 亚洲成人福利在线 | 精品欧美成人高清在线观看2021 | 日韩国产免费 | 国产精品香蕉一区二区三区 | 女人张开腿让男人捅的视频 | 欧美久久久久 | 成年人在线免费观看视频网站 | 久久国产视屏 | 欧美在线综合 |