日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

淺談JavaScript中this的指向問題

瀏覽:241日期:2023-10-19 17:26:30

JavaScript中this指向問題

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

先記住攻克 this 指向問題的口訣(前輩們的總結):哪個對象調用函數,函數里的 this 就默認指向哪個對象(注意 this 只能指向對象)。這里說“默認指向”是因為我們通過箭頭函數、call、apply、bind等手段來改變 this 的指向。現在我們只討論 this 的默認指向。

全局作用域下以及全局作用域的函數中,this默認指向全局對象window

在嚴格模式下,全局作用域的函數中,this默認指向 undefined, 這是嚴格模式所規定的。

// 非嚴格模式下console.log(this); // Windowfunction doSomething(){ console.log(this); // Window}doSomething(); // 這里可以看成window.doSomething(),所以函數里的this指向全局對象window// 嚴格模式下’use strict’;console.log(this); // Windowfunction 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 的綁定對象。

由 new 調用?綁定到新創建的實例對象上。 由 call、apply、bind調用?綁定到指定的對象上。 由上下文對象調用?綁定到那個上下文對象上。 默認:在嚴格模式下綁定到 undefined,否則綁定到全局對象 Window 上。 ES6 中的箭頭函數會繼承外層函數調用的 this 綁定,這和 var self = this;的綁定機制一樣。

到此這篇關于淺談JavaScript中this的指向問題的文章就介紹到這了,更多相關JavaScript中this指向問題內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲国产福利| 天堂av在线| 久久99蜜桃| 欧美精品一区二区久久| 国产精品1luya在线播放| 国产亚洲一区在线| 国产aⅴ精品一区二区四区| 国产偷自视频区视频一区二区| 玖玖玖国产精品| 久久中文字幕二区| 麻豆极品一区二区三区| 国产精品一区二区三区av| 欧美一区成人| 国产精品手机在线播放| 久久黄色影视| 日韩成人午夜精品| 亚久久调教视频| 日韩中文欧美在线| 国产精品毛片| 精品视频一区二区三区在线观看| 视频一区二区三区在线| 久久久精品午夜少妇| 国产精品毛片aⅴ一区二区三区| 国产剧情在线观看一区| 在线亚洲观看| 欧美日韩水蜜桃| 91精品国产调教在线观看| 97精品一区二区| 久久在线91| 国产精品二区影院| 国产精品夜夜夜| 国产精品日韩精品在线播放| 国产精品magnet| 蜜桃久久av| 亚洲欧洲美洲国产香蕉| 视频一区二区三区入口| 久久精品亚洲欧美日韩精品中文字幕| 日韩av网站在线免费观看| 精品视频自拍| 国产成人精品999在线观看| 午夜在线视频一区二区区别| 国内精品麻豆美女在线播放视频| 日韩福利视频一区| 精品网站999| 99久久久久| 亚洲综合小说| 欧美日韩1区2区3区| 99国产精品免费视频观看| 视频在线观看一区| 国产日韩精品视频一区二区三区| 精品久久视频| 亚洲视频综合| 日本国产一区| 国产精品一区二区三区四区在线观看 | 欧美aa在线观看| 免费不卡中文字幕在线| 亚洲最新av| 另类专区亚洲| 蜜桃免费网站一区二区三区| 国产美女亚洲精品7777| 久久亚洲专区| 性色一区二区| 日韩av首页| 亚洲开心激情| 久久久久久久久久久妇女| 午夜亚洲福利| 999国产精品| 久久99性xxx老妇胖精品| 亚洲美洲欧洲综合国产一区| 精品亚洲a∨一区二区三区18| 亚洲欧美日韩国产综合精品二区| 久久久国产精品网站| 蜜桃tv一区二区三区| 国产精品一线| 亚洲免费资源| 91精品二区| 久久精品影视| 国产亚洲精品精品国产亚洲综合| 国产欧美一区二区三区国产幕精品 | 欧美一级专区| 亚洲h色精品| 91欧美国产| 视频在线在亚洲| 日本免费新一区视频| av不卡在线| 亚洲一区资源| a天堂资源在线| 91亚洲一区| 色一区二区三区| 成人美女视频| 福利一区二区免费视频| 精品一区电影| 在线人成日本视频| 日本不卡免费高清视频在线| 久久久久久夜| 久久亚洲精品中文字幕蜜潮电影| 婷婷国产精品| 蜜臀av一区二区三区| 亚洲精品一二| 国产精品三p一区二区| 国产精品一站二站| 久久亚洲精品中文字幕| 福利在线免费视频| 久久久久久美女精品| 中文精品在线| 日韩av电影一区| 国产精品va| 欧美三级精品| 蜜桃久久av一区| 日韩一区精品| 亚洲精品在线二区| 国产乱子精品一区二区在线观看| 国产亚洲一区| 久久国产中文字幕| 日韩一区二区三区四区五区| 免费人成网站在线观看欧美高清| 少妇精品导航| 中文字幕乱码亚洲无线精品一区| 日本亚洲视频在线| 黄在线观看免费网站ktv| 黄色亚洲免费| 国产精品亚洲综合在线观看| 色婷婷精品视频| 日本色综合中文字幕| 成人美女视频| 国产精品一区高清| 国产视频一区免费看| 精品一区二区三区中文字幕视频 | 麻豆高清免费国产一区| 午夜国产精品视频| 欧美国产另类| 久久国产88| 日韩不卡免费高清视频| 日韩一区精品视频| 欧美天堂亚洲电影院在线观看| 欧美激情另类| 久久精品99国产精品| 久久福利精品| 免费国产自久久久久三四区久久 | 黄色av日韩| 红杏一区二区三区| 国产日韩在线观看视频| 免费观看久久久4p| 一区视频在线| 免费国产自久久久久三四区久久| 精品国产欧美| 欧美国产精品| 国产高清日韩| 青草av.久久免费一区| 美美哒免费高清在线观看视频一区二区| 人人香蕉久久| 欧美日韩精品免费观看视欧美高清免费大片 | 久久精品一区二区国产| 男女男精品视频网| 91高清一区| 午夜一级久久| 中文亚洲欧美| 今天的高清视频免费播放成人| 中文字幕成在线观看| 色婷婷精品视频| 五月综合激情| 日韩精品五月天| 欧美一级久久| 国精品产品一区| 日韩免费小视频| 激情视频一区二区三区| 香蕉精品视频在线观看| 99热精品在线观看| aⅴ色国产欧美| 欧美有码在线| 成人午夜毛片| 欧美亚洲国产激情| 亚洲天堂1区| 2023国产精品久久久精品双| 亚洲成人免费| 日韩精品三区四区| 国产日韩亚洲| 免费观看久久av| 欧美日韩中文| 欧美丝袜一区| 精品一区二区三区中文字幕在线| 婷婷综合网站| 欧美日韩1区| 亚洲四虎影院| 91久久精品无嫩草影院| 蜜桃av.网站在线观看| 国产一级久久| 精品三级国产| 亚洲欧美日韩综合国产aⅴ| 国产精品免费不| 欧美精品羞羞答答| 国产欧美日本| 日韩一区欧美二区| 国产盗摄——sm在线视频| 爽好久久久欧美精品| 亚洲三级欧美| 欧美片第1页综合| 在线亚洲免费| 亚洲一级少妇| 麻豆国产精品一区二区三区|