国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - 詳解JavaScript中的this指向問題

詳解JavaScript中的this指向問題

2022-01-17 16:43清蒸胖頭魚 js教程

這篇文章主要介紹了詳解JavaScript中的this指向問題,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下

題記

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

開篇

首先我們都知道this是Javascript語言的一個關(guān)鍵字。

它代表函數(shù)運行時,自動生成的一個內(nèi)部對象,只能在函數(shù)內(nèi)部使用。隨著函數(shù)使用場合的不同,this的值會發(fā)生變化。但是有一個總的原則,那就是this的指向在函數(shù)定義的時候是確定不了的,只有函數(shù)執(zhí)行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調(diào)用它所在函數(shù)的對象。 那么接下來我們一步步探索下這個問題。

探索一

?
1
2
3
4
5
6
7
function a() {
  var user = "清蒸胖頭魚";
  console.log(this.name); //undefined
  console.log(this); //Window
 }
 a();
 window.a();//兩種結(jié)果相同

如我們上文所說的this的最終指向的是那個調(diào)用它所在函數(shù)的對象,這里a其實是由window對象點出來的。

探索二

?
1
2
3
4
5
6
7
var obj = {
  name: '清蒸胖頭魚',
  f1: function () {
   console.log(this.name);//清蒸胖頭魚
  }
 };
 obj.f1();

再次強(qiáng)調(diào)一點this的指向在函數(shù)定義的時候是確定不了的,只有函數(shù)執(zhí)行的時候才能確定this到底指向誰;這個例子this所在的f1函數(shù)是由obj對象調(diào)用的,所以這里的this指向obj對象。

探索三

如果要徹底的搞懂this必須看接下來的幾個例子

?
1
2
3
4
5
6
7
8
9
10
var obj = {
  a: 5,
  b: {
   a: 10,
   fn: function () {
    console.log(this.a); //10
   }
  }
 };
 obj.b.fn();

不是說this的最終指向的是那個調(diào)用它所在函數(shù)的對象嗎?這里為什么不指向obj對象呢?

這里需要補(bǔ)充三點:

  1. 如果一個函數(shù)中有this,但是它沒有被上一級的對象所調(diào)用,那么this指向的就是window。
  2. 如果一個函數(shù)中有this,這個函數(shù)有被上一級的對象所調(diào)用,那么this指向的就是上一級的對象。
  3. 如果一個函數(shù)中有this,這個函數(shù)中包含多個對象,盡管這個函數(shù)是被最外層的對象所調(diào)用,this指向的也只是它上一級的對象。

看到這相信大家基本掌握了this指向的原則了吧,再碎碎念一遍:this的指向在函數(shù)定義的時候是確定不了的,只有函數(shù)執(zhí)行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調(diào)用它所在函數(shù)的對象。

下面給大家介紹this幾種不同的使用情況

構(gòu)造函數(shù)(new 關(guān)鍵字)情況

?
1
2
3
4
5
function Student() {
  this.name = '清蒸胖頭魚';
 }
 var s1 = new Student();
 console.log(s1.name);// 清蒸胖頭魚

這里之所以對象s1可以點出函數(shù)Student里面的name 是因為new關(guān)鍵字可以改變this的指向,將這個this指向?qū)ο髎1.

?
1
2
3
4
5
// new 關(guān)鍵字執(zhí)行的過程
 1. 在函數(shù)體內(nèi)創(chuàng)建一個空的對象.
 2. 讓當(dāng)前this指向這個空的對象.
 3. 通過this給當(dāng)前空的對象添加鍵值對.
 4. 返回已經(jīng)添加好所有鍵值對的對象給外面的變量.

定時器里的this指向情況

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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的指向在函數(shù)定義的時候是確定不了的,只有函數(shù)執(zhí)行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調(diào)用它所在函數(shù)的對象。

解: this.num所在的函數(shù)為定時器setInterval內(nèi)的function () { console.log(this.num);},根據(jù)this指向原則當(dāng)該函數(shù)被執(zhí)行,this指向它的上一級對象。setInterval,又因setIntervalwindow點出了的,所以this指向window

callapplybind 改變指向情況

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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綁定到這個函數(shù)上
  };
 }
 var o = new Obj();
 o.getNum1();//1  (o.num)
 o.getNum2();//1 (o.num)

解釋:

bind()方法是Function.prototype上的一個方法,當(dāng)被綁定函數(shù)調(diào)用時,bind方法會創(chuàng)建一個新函數(shù),并將第一個參數(shù)作為新函數(shù)的運行時的this。

根據(jù)原則:

沒使用bind方法前:被調(diào)用時:this.num指向的是調(diào)用它所在函數(shù)的對象,也就是window.setTimeout對象。 使用bind方法后:被調(diào)用時:將原來的this重新指向到→調(diào)用getSum2函數(shù)(就是新this所在的函數(shù))的對象。這里構(gòu)造函數(shù),通過new調(diào)用,所以指向o對象。

bind方法在該情況比較常用,當(dāng)然如果使用callapply方法來代替也行,得到的結(jié)果也是正確的,但是callapply方法會在調(diào)用后馬上執(zhí)行,那樣就沒了延時的效果,定時器也就沒有意義了。

以上就是詳解JavaScript中的this指向問題的詳細(xì)內(nèi)容,更多關(guān)于JavaScript this指向的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://juejin.cn/post/6924956367577546759

延伸 · 閱讀

精彩推薦
  • js教程使用js原生實現(xiàn)年份輪播選擇效果實例

    使用js原生實現(xiàn)年份輪播選擇效果實例

    這篇文章主要給大家介紹了關(guān)于如何使用js原生實現(xiàn)年份輪播選擇效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的...

    Hui-101810732021-12-30
  • js教程JavaScript事件概念詳解(區(qū)分靜態(tài)注冊和動態(tài)注冊)

    JavaScript事件概念詳解(區(qū)分靜態(tài)注冊和動態(tài)注冊)

    這篇文章主要介紹了JavaScript事件(區(qū)分靜態(tài)注冊和動態(tài)注冊)的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下...

    皮卡丘和羊?qū)氊?/span>6762022-01-17
  • js教程原生JS實現(xiàn)音樂播放器

    原生JS實現(xiàn)音樂播放器

    這篇文章主要為大家詳細(xì)介紹了原生JS音樂播放器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    奶茶只要半糖3592022-01-07
  • js教程原生js實現(xiàn)滑塊區(qū)間組件

    原生js實現(xiàn)滑塊區(qū)間組件

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)滑塊區(qū)間組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    蒲公英芽11882022-01-05
  • js教程JS代碼實現(xiàn)頁面切換效果

    JS代碼實現(xiàn)頁面切換效果

    這篇文章主要為大家詳細(xì)介紹了JS代碼實現(xiàn)頁面切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    _Adoph9322021-12-29
  • js教程微信小程序抽獎組件的使用步驟

    微信小程序抽獎組件的使用步驟

    這篇文章主要給大家介紹了關(guān)于微信小程序抽獎組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需...

    い 狂奔的蝸牛10812021-12-29
  • js教程js實現(xiàn)簡單的倒計時

    js實現(xiàn)簡單的倒計時

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)簡單的倒計時,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    搬磚大法8232022-01-10
  • js教程了不起的11個JavaScript代碼重構(gòu)最佳實踐小結(jié)

    了不起的11個JavaScript代碼重構(gòu)最佳實踐小結(jié)

    這篇文章主要介紹了了不起的11個JavaScript代碼重構(gòu)最佳實踐小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需...

    pikapi3832021-12-29
主站蜘蛛池模板: 欧美日韩高清一区 | 欧美一区二区三区在线 | 亚洲成人av在线 | 亚洲精品成人av | 亚洲欧美福利视频 | 久久99精品视频 | 狠狠ri| 久久天天操 | 国产在线观看免费 | 日韩精品一区二区三区中文在线 | 久操视频在线 | 综合久久av | 精品久久中文字幕 | 中国一级黄色 | 欧美黄视频 | 亚洲一区二区久久 | 荷兰欧美一级毛片 | 精品视频免费观看 | 亚洲视频精品在线 | 美女毛片| 日韩精品99久久久久中文字幕 | 色天天天天色 | 性做久久久久久久久 | 亚洲精选久久 | 99热最新网址| 99这里只有精品 | 亚洲啪啪网站 | 日本黄色网址大全 | 欧美高清一区 | 久久av网 | 一区二区三区免费看 | 寡妇少妇高潮免费看蜜臀a 午夜免费电影 | 在线a视频 | 日韩第一区 | 欧美一级在线视频 | 免费h在线观看 | 国产精品视频一二三区 | 欧美一区二区三区久久精品 | 91经典在线 | 国产精品一区二区不卡 | 亚洲精品福利在线观看 |