成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

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

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

先記住攻克 this 指向問題的口訣(前輩們的總結(jié)):哪個(gè)對(duì)象調(diào)用函數(shù),函數(shù)里的 this 就默認(rèn)指向哪個(gè)對(duì)象(注意 this 只能指向?qū)ο螅_@里說“默認(rèn)指向”是因?yàn)槲覀兺ㄟ^箭頭函數(shù)、call、apply、bind等手段來改變 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();

先說下執(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)用沒有關(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()

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

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

標(biāo)簽: JavaScript
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品正在播放| 久久久.com| 日本久久一区二区三区| 精品久久一区二区| 亚洲黄色免费网站| 大陆成人av片| 一区二区三区四区五区视频 | 成人免费福利片| 香蕉成人久久| 久久这里都是精品| 日本美女视频一区二区| 欧美尤物一区| 欧美日韩精品一区二区天天拍小说 | 欧美国产专区| 欧美三区免费完整视频在线观看| 日本一区免费视频| 国产一区二区网址| 亚洲一区二区毛片| 久久色在线观看| 麻豆91免费看| 亚洲精品视频啊美女在线直播| 欧美一级日韩一级| 亚洲成a人片综合在线| 欧美fxxxxxx另类| 欧美在线播放高清精品| 亚洲色图在线视频| 豆国产96在线|亚洲| 老**午夜毛片一区二区三区| 国产精品欧美一区二区三区| 国产一区亚洲一区| 国产日韩在线一区二区三区| 久久久久综合网| 精品写真视频在线观看| 亚洲欧美日韩综合国产aⅴ| 国产欧美久久久精品影院| 韩国女主播一区| 久久精品国产99精品国产亚洲性色| 久久午夜色播影院免费高清 | 狠狠狠色丁香婷婷综合久久五月| 亚洲欧洲日韩综合二区| 精品粉嫩超白一线天av| 久久99国内精品| 久久精品一区二区国产| 亚洲欧洲精品一区二区精品久久久 | 91在线观看高清| 欧美又粗又大又爽| 亚洲成va人在线观看| 亚洲国产精品久久久久婷婷老年| 精品国产在天天线2019| 国产一区二区女| 久久久久高清| 亚洲专区一二三| 国产综合视频| 久久久久综合网| 岛国av在线一区| 欧美老人xxxx18| 另类小说综合欧美亚洲| 一本大道久久精品懂色aⅴ| 亚洲日本丝袜连裤袜办公室| 欧美伊人久久| 2023国产精品| 播五月开心婷婷综合| 日韩一级精品视频在线观看| 国产在线国偷精品免费看| 欧美丝袜丝nylons| 免费看黄色91| 久久三级视频| 一区二区在线观看不卡| 国产精品hd| 中文字幕精品一区二区三区精品| www.亚洲色图.com| 日韩欧美在线网站| 精品系列免费在线观看| 欧美日韩在线播放三区四区| 免费一区二区视频| 91黄视频在线| 日韩av电影天堂| 久久精品二区| 日韩精品一二三区| 色噜噜狠狠一区二区三区果冻| 天天综合天天做天天综合| 免费视频一区| 视频一区欧美日韩| 色婷婷久久久亚洲一区二区三区| 亚洲精品国产一区二区三区四区在线| 精品91免费| 亚洲欧美日韩中文播放| 一本色道久久综合| 亚洲精品日韩一| 亚洲图片在线| 亚洲视频在线观看一区| 精品1区2区| 一区二区成人在线观看| 亚洲一区二区三区精品视频| 亚洲电影一级黄| 久久国产精品久久w女人spa| 婷婷六月综合亚洲| 欧美色综合久久| 国产xxx精品视频大全| 精品久久人人做人人爱| 99麻豆久久久国产精品免费| 欧美精彩视频一区二区三区| 欧美另类专区| 最新不卡av在线| 久久成人免费| 美腿丝袜亚洲三区| 欧美日韩精品三区| 成人av资源在线观看| 欧美国产一区视频在线观看| 一区在线免费观看| 亚洲一区二区三区自拍| 久久激情一区| 精品一区二区三区欧美| 日韩一二在线观看| 色综合中文字幕国产| 综合久久久久综合| 美日韩精品免费| 久久99精品一区二区三区| 欧美一区二区三区四区久久| 91蝌蚪porny九色| 亚洲自拍与偷拍| 欧美色爱综合网| 成人免费毛片嘿嘿连载视频| 国产欧美久久久精品影院| 国产精品普通话对白| 美女视频一区二区三区| 精品国产一区二区亚洲人成毛片| 欧美连裤袜在线视频| 亚洲午夜日本在线观看| 欧美视频一区二区三区四区 | 国产在线视频精品一区| 久久婷婷成人综合色| 91久久亚洲| 久久精品国产久精国产| 久久综合国产精品| 国产日韩亚洲| 国产尤物一区二区| 欧美国产日产图区| 美女黄色成人网| 国产成人免费视频网站高清观看视频| 国产欧美精品日韩区二区麻豆天美| 亚洲欧洲日韩综合二区| 美女免费视频一区| 久久精品一区八戒影视| 99精品国产高清一区二区 | 激情视频一区| 麻豆国产精品官网| 欧美激情综合五月色丁香小说| 久久精品一本| 94色蜜桃网一区二区三区| 亚洲高清视频在线| 欧美一卡2卡三卡4卡5免费| 亚洲黄色影片| 国内成人自拍视频| 国产精品久久久久精k8| 91国产福利在线| 欧美日韩视频| 久色婷婷小香蕉久久| 国产人久久人人人人爽| 久久久精品动漫| 欧美一区二区三区另类| 日日摸夜夜添夜夜添国产精品 | 91看片淫黄大片一级| 午夜精品福利一区二区蜜股av| 日韩女同互慰一区二区| 蘑菇福利视频一区播放| 国产成人精品亚洲午夜麻豆| 亚洲精品乱码久久久久| 日韩午夜激情电影| 亚洲欧美网站| 91一区二区在线| 日本免费新一区视频| 国产精品久久久久久久久免费相片| 91福利在线播放| 欧美日韩在线一二三| 国产在线观看一区二区| 亚洲一二三级电影| 欧美经典一区二区| 91精品国产综合久久香蕉麻豆| 亚洲精品一区二| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 久久众筹精品私拍模特| 一本大道久久a久久精二百| 欧美日韩三级电影在线| 国产麻豆成人传媒免费观看| 亚洲精品国产无天堂网2021| 精品成人一区二区| 在线影院国内精品| 伊人天天综合| 成人短视频下载| 日韩电影在线一区二区| 亚洲欧洲成人自拍| 精品国产免费一区二区三区香蕉| 色一情一伦一子一伦一区| 国内精品久久久久久久果冻传媒 | 亚洲一区二区成人| 激情综合中文娱乐网| 91亚洲精华国产精华精华液| 久热成人在线视频| 亚洲国产视频a|