中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

JavaScript中this指向什么

發布時間:2021-02-05 13:36:51 來源:億速云 閱讀:133 作者:Leah 欄目:開發技術

JavaScript中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對象呢?

這里需要補充三點:

  1. 如果一個函數中有this,但是它沒有被上一級的對象所調用,那么this指向的就是window。

  2. 如果一個函數中有this,這個函數有被上一級的對象所調用,那么this指向的就是上一級的對象。

  3. 如果一個函數中有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,又因setIntervalwindow點出了的,所以this指向window

callapplybind 改變指向情況

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方法在該情況比較常用,當然如果使用callapply方法來代替也行,得到的結果也是正確的,但是callapply方法會在調用后馬上執行,那樣就沒了延時的效果,定時器也就沒有意義了。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

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

AI

长寿区| 库车县| 杂多县| 鄂托克旗| 织金县| 汉川市| 通山县| 高清| 新化县| 珠海市| 扎鲁特旗| 太原市| 马公市| 丽水市| 双柏县| 云霄县| 五常市| 新闻| 徐汇区| 伊宁市| 大连市| 肥城市| 林芝县| 健康| 乌恰县| 保亭| 秦安县| 印江| 玉环县| 诸暨市| 新沂市| 开平市| 卢湾区| 绥化市| 康乐县| 湟源县| 宁海县| 长武县| 安徽省| 台山市| 新和县|