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

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

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

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

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

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

全局作用域下以及全局作用域的函數(shù)中,this默認(rèn)指向全局對象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指向全局對象window// 嚴(yán)格模式下’use strict’;console.log(this); // Windowfunction doInStrict(){ console.log(this); // undefined}doInStrict();

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

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é)果可以看出此時 this 指向的是調(diào)用函數(shù)的對象 obj。如果將對象中的函數(shù)賦給全局對象中定義的變量 fn1,執(zhí)行 fn1 又會出現(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)用它的對象不同,那么函數(shù)中 this 的指向也就不一樣了。

再看一個比較復(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ù)時,先執(zhí)行的是 fn(),這個函數(shù)是在全局作用域中定義的,該調(diào)用可以看成 window.fn(),所以,該函數(shù)內(nèi)部的 this 指向的是 window 全局對象,this.a 自然就是全局對象中的 a 值(0)。

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

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

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

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

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

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

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

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品综合| 天堂va在线高清一区| 蜜桃传媒麻豆第一区在线观看 | 国产精品大片| 日韩一区二区三区在线看| 欧美专区18| 日本在线一区二区三区| 日本伊人久久| 精品视频亚洲| 亚洲大片在线| 中文字幕中文字幕精品| 911精品国产| 黑人精品一区| 亚洲v在线看| 快she精品国产999| 国产精品久久久一区二区| 欧美极品中文字幕| 91精品在线观看国产| 男女男精品视频网| 国产亚洲精品美女久久| 日韩电影免费网站| 亚洲综合电影一区二区三区| 日韩**一区毛片| 97人人精品| 亚洲欧美网站在线观看| 国产a久久精品一区二区三区| 女主播福利一区| 国产精品香蕉| 香蕉精品久久| 日韩av不卡在线观看| 亚洲国内欧美| 视频一区二区不卡| 国内精品亚洲| 免费在线观看一区二区三区| 久久一区亚洲| 日本成人在线不卡视频| 久久精品免费一区二区三区| 国产欧美日韩视频在线| 中文一区二区| 少妇精品导航| 精品国产乱码久久久久久1区2匹| 丝袜a∨在线一区二区三区不卡| 久久伊人久久| 中文字幕日本一区二区| 欧美 日韩 国产精品免费观看| 欧美激情五月| 国产午夜精品一区在线观看| 噜噜噜久久亚洲精品国产品小说| 亚洲永久av| 成人污污视频| 久久香蕉精品香蕉| 国产精品手机在线播放| 亚州av一区| 亚洲视频二区| 最新国产精品视频| 热久久免费视频| 首页国产欧美久久| 亚洲一区中文| 999久久久国产精品| 综合日韩av| 新版的欧美在线视频| 中文在线资源| 久久一级电影| 午夜精品一区二区三区国产| 国产网站在线| 久久九九精品| av不卡免费看| 视频一区日韩精品| 日韩欧美在线精品| 国产福利一区二区精品秒拍| 国产激情欧美| 日韩国产在线| 一区在线观看| 亚洲在线成人| 欧美片网站免费| 国产福利91精品一区二区| 日韩欧美1区| 亚洲一区二区三区高清不卡| 亚洲精品在线二区| 国产精品二区影院| 视频福利一区| 日韩一区免费| 日韩电影免费在线观看| 国产免费成人| 国产精品v一区二区三区| 国产不卡av一区二区| 久久精品卡一| 欧美日本三区| 韩国精品主播一区二区在线观看| 好吊日精品视频| 欧美日韩1区2区3区| 五月激情久久| 国产三级一区| 午夜国产欧美理论在线播放 | 国产一区日韩欧美| 91精品国产自产在线丝袜啪| 日韩一区三区| 啪啪亚洲精品| 黄色亚洲精品| 美女视频黄久久| 免费日韩av| 久久精品青草| 精品黄色一级片| 中文字幕日韩高清在线| 久久久国产精品一区二区中文| 日韩不卡一二三区| 黑丝一区二区| 中文一区一区三区高中清不卡免费| 亚洲精品系列| 日韩一级不卡| 日本精品在线中文字幕| 欧美1区2区3| 欧美日韩在线精品一区二区三区激情综合| 99精品视频在线| 国产精品男女| 中文字幕成人| 在线观看一区| 精品91久久久久| 亚洲成人一区| 久久亚洲国产| 国产精品7m凸凹视频分类| 国产福利电影在线播放| 欧美激情在线精品一区二区三区| 日本国产一区| 国产调教一区二区三区| 91在线成人| 欧美一区在线观看视频| 日韩精品亚洲aⅴ在线影院| 视频一区欧美日韩| 99国产成+人+综合+亚洲欧美| 欧美一区二区三区激情视频| 久久精品资源| 亚洲日本免费电影| 欧洲激情综合| 亚洲精品一级二级| 欧美视频久久| 日本成人在线一区| 国产欧美三级| 色婷婷亚洲mv天堂mv在影片| 亚洲精品在线影院| 欧美日韩视频一区二区三区| 免费日韩av片| 久久精品72免费观看| 国产一区一一区高清不卡| 久久精品国产久精国产爱| 卡一精品卡二卡三网站乱码| 伊人久久视频| 在线亚洲精品| 国产伦理一区| 91精品一区国产高清在线gif| 亚洲欧美久久| 国产精品调教视频| 国产专区一区| 日韩精品一区二区三区中文| 精品国产欧美日韩| 日韩午夜av| 黄色网一区二区| 石原莉奈一区二区三区在线观看| 国产伦一区二区三区| 亚洲第一精品影视| 亚洲精品三级| 日韩精品一区二区三区免费观看| 亚洲精品动态| 亚洲高清毛片| 国产精品.xx视频.xxtv| 午夜欧美视频| 精品美女视频 | 国产一区调教| 亚洲小说春色综合另类电影| 精品视频一二| 日韩激情中文字幕| 不卡中文字幕| 蜜桃精品在线| 国产成人精品一区二区三区在线| 亚洲天堂日韩在线| 久久精品国产68国产精品亚洲| 国产精品午夜一区二区三区| 美日韩精品视频| 亚洲黄色免费av| 美女毛片一区二区三区四区最新中文字幕亚洲| 99精品99| 婷婷成人基地| 久久中文亚洲字幕| 久久精品天堂| 国产精品qvod| 国产精品一区二区三区av| 午夜久久av| 亚洲精选成人| 日韩欧美2区| 日韩欧美高清一区二区三区| 午夜在线视频观看日韩17c| 红桃视频亚洲| 日韩在线卡一卡二| 亚洲精品日韩久久| 日本一区二区中文字幕| 一区二区精品| 亚欧成人精品| 国产精品极品| 国产乱码精品| 欧美xxxx中国|