<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      JavaScript中this指向問題

      JavaScript中this指向問題

      記得初學 JavaScript 時,其中 this 的指向問題曾讓我頭疼不已,我還曾私自將其與閉包、原型(原型鏈)并稱 JS 武林中的三大魔頭。如果你要想在 JS 武林中稱霸一方,必須將這三大魔頭擊倒。個人認為在這三大魔頭中,this 指向問題的武功最菜(難度最低)。俗話說柿子撿軟的捏,那我們就先從 this 指向問題下手。

      先記住攻克 this 指向問題的口訣(前輩們的總結):哪個對象調用函數,函數里的 this 就默認指向哪個對象(注意 this 只能指向對象)。這里說“默認指向”是因為我們通過箭頭函數、call、apply、bind等手段來改變 this 的指向?,F在我們只討論 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 的指向。 請參考JS中this指向的更改,這里就不再贅述了。
      this 既不指向函數自身也不指向函數的詞法作用域,this 實際上是在函數被調用時發生的綁定,它指向什么完全取決于函數在哪里被調用。
      找到函數直接調用的位置后用下面的幾條規則就可以判斷出 this 的綁定對象。

      1. 由 new 調用?綁定到新創建的實例對象上。
      2. 由 call、apply、bind調用?綁定到指定的對象上。
      3. 由上下文對象調用?綁定到那個上下文對象上。
      4. 默認:在嚴格模式下綁定到 undefined,否則綁定到全局對象 Window 上。
      5. ES6 中的箭頭函數會繼承外層函數調用的 this 綁定,這和 var self = this;的綁定機制一樣。
      posted @ 2020-07-07 18:58  老甄Home  閱讀(597)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 国产精品一品二区三四区| 久久午夜无码鲁丝片直播午夜精品| 亚洲成a人片77777kkkk| 日韩加勒比一本无码精品| 一本色道久久综合熟妇人妻| 亚洲一区二区精品另类| 疯狂做受xxxx高潮欧美日本| 国产超高清麻豆精品传媒麻豆精品| 国产精品成人一区二区不卡| 亚洲精品日韩中文字幕| 亚洲av无码精品色午夜蛋壳| 开心久久综合激情五月天| 亚洲成av人片无码天堂下载| 国产丰满老熟女重口对白| 国产成人精品一区二区三区免费| 国产无遮挡真人免费视频| 好先生在线观看免费播放| 日日碰狠狠添天天爽五月婷| 日韩国产欧美精品在线 | 亚洲色一色噜一噜噜噜| 国精一二二产品无人区免费应用| 国产精品疯狂输出jk草莓视频| 视频一区视频二区卡通动漫| 久久天天躁狠狠躁夜夜躁2012| 国产日韩久久免费影院| 综合色综合色综合色综合| 在线播放亚洲人成电影| 亚洲欧美综合人成在线| 亚洲精品乱码久久观看网| 免费观看的AV毛片的网站不卡| jizzjizz少妇亚洲水多| 国产精品∧v在线观看| 国精品无码一区二区三区在线蜜臀| 熟妇激情一区二区三区| 国产免费久久精品44| 亚洲欧美日产综合在线网| 花垣县| 性色av一区二区三区精品| 人成午夜免费大片| 性色高清xxxxx厕所偷窥| 久久久久久国产精品美女|