国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript this指向相關(guān)原理及實(shí)例解析

瀏覽:81日期:2023-10-21 16:03:52

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

先記住攻克 this 指向問(wèn)題的口訣(前輩們的總結(jié)):哪個(gè)對(duì)象調(diào)用函數(shù),函數(shù)里的 this 就默認(rèn)指向哪個(gè)對(duì)象(注意 this 只能指向?qū)ο螅_@里說(shuō)“默認(rèn)指向”是因?yàn)槲覀兺ㄟ^(guò)箭頭函數(shù)、call、apply、bind等手段來(lái)改變 this 的指向。現(xiàn)在我們只討論 this 的默認(rèn)指向。

全局作用域下以及全局作用域的函數(shù)中,this默認(rèn)指向全局對(duì)象window

在嚴(yán)格模式下,全局作用域的函數(shù)中,this默認(rèn)指向 undefined, 這是嚴(yán)格模式所規(guī)定的。

// 非嚴(yán)格模式下console.log(this); // Windowfunction doSomething(){ console.log(this); // Window}doSomething(); // 這里可以看成window.doSomething(),所以函數(shù)里的this指向全局對(duì)象window// 嚴(yán)格模式下’use strict’;console.log(this); // Windowfunction doInStrict(){ console.log(this); // undefined}doInStrict();

對(duì)象里的函數(shù),this指向該對(duì)象

var a = 1;var obj = { a: 2, fn: function(){ console.log(this); // {a: 2, fn: ƒ} console.log(this.a); // 2 }};obj.fn();

上面函數(shù)被調(diào)用后,從打印結(jié)果可以看出此時(shí) this 指向的是調(diào)用函數(shù)的對(duì)象 obj。如果將對(duì)象中的函數(shù)賦給全局對(duì)象中定義的變量 fn1,執(zhí)行 fn1 又會(huì)出現(xiàn)什么結(jié)果呢?

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 指向的函數(shù)是相同的,但是調(diào)用它的對(duì)象不同,那么函數(shù)中 this 的指向也就不一樣了。

再看一個(gè)比較復(fù)雜的例子:

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();

先說(shuō)下執(zhí)行結(jié)果,分別打印 0 1 2。當(dāng) obj2 調(diào)用 fn 函數(shù)時(shí),先執(zhí)行的是 fn(),這個(gè)函數(shù)是在全局作用域中定義的,該調(diào)用可以看成 window.fn(),所以,該函數(shù)內(nèi)部的 this 指向的是 window 全局對(duì)象,this.a 自然就是全局對(duì)象中的 a 值(0)。

接著執(zhí)行的是 obj1.fn(),它會(huì)從 obj1 中找到 fn 函數(shù)并執(zhí)行。obj1 中的函數(shù) fn 執(zhí)行時(shí)調(diào)用它的對(duì)象是 obj1,所以,此時(shí)函數(shù)內(nèi)部的 this 指向的就是 obj1 自身。那么 this.a 查到的值也就是對(duì)象 obj1 中 a 的值(1)。

最后打印函數(shù)中 this 所處的函數(shù) fn 是被 obj2 調(diào)用的,那么自然而然 this 就指向了 obj2,所以 this.a 的結(jié)果就是 2 了。

從上面這個(gè)例子我們可以看出:函數(shù)內(nèi)部 this 指向跟調(diào)用函數(shù)的對(duì)象有關(guān),跟函數(shù)在哪里調(diào)用沒(méi)有關(guān)系。

Window內(nèi)置函數(shù)的回調(diào)函數(shù)中,this指向Window對(duì)象。window 的內(nèi)置函數(shù)( setInterval setTimeout 等),其回調(diào)函數(shù)中的 this 指向的是window對(duì)象。

var name = ’window’;var obj = { name: ’obj’, func: function(){ setTimeout(function () { console.log(this.name) // window },1000) }}obj.func()

但是一般在開(kāi)發(fā)中,很多場(chǎng)景都需要改變 this 的指向。 后面我會(huì)專門寫一篇關(guān)于更改 this 指向的文章,這里就不再贅述了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 在线中文字幕精品第5页 | 中国a级毛片免费 | 国产成人v爽在线免播放观看 | 成人免费视频在线 | 成人免费一级在线播放 | 高清韩国a级特黄毛片 | 国产激情视频网站 | 国产精品反差婊在线观看 | 精品欧美一区视频在线观看 | 日韩国产欧美一区二区三区 | 欧美一区二区三区精品 | 亚洲一区视频在线 | 成人看片黄a免费看视频 | 国产午夜小视频 | 欧美一做特黄毛片 | 国产精品怡红院在线观看 | 国产欧美综合在线一区二区三区 | 97国产成人精品视频 | 中文字幕一区2区 | 久久综合色播 | a理论片| 日韩色视频一区二区三区亚洲 | 亚洲www在线| 国产特黄特色的大片观看免费视频 | 北条麻妃在线一区二区 | 性做久久久久久免费观看 | 国产精品高清久久久久久久 | 国产私拍福利精品视频推出 | 日本精品网| 德国女人一级毛片免费 | 国产伦精一区二区三区视频 | 国产全部理论片线观看 | 在线另类视频 | 久草视频手机在线观看 | 国产在线一区二区三区四区 | 在线成人aa在线看片 | 成年人免费在线视频网站 | 欧美a一| 港台三级在线观看 | a一级免费视频 | 国产精品成人亚洲 |