<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
        當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

        靈活的理解JavaScript中的this指向_javascript技巧

        來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 20:51:24
        文檔

        靈活的理解JavaScript中的this指向_javascript技巧

        靈活的理解JavaScript中的this指向_javascript技巧:this是JavaScript中的關(guān)鍵字之一,在編寫(xiě)程序的時(shí)候經(jīng)常會(huì)用到,正確的理解和使用關(guān)鍵字this尤為重要。首先必須要說(shuō)的是,this的指向在函數(shù)定義的時(shí)候是確定不了的,只有函數(shù)執(zhí)行的時(shí)候才能確定this到底指向誰(shuí),實(shí)際上this的最終指向的是那個(gè)調(diào)用它的對(duì)象(這
        推薦度:
        導(dǎo)讀靈活的理解JavaScript中的this指向_javascript技巧:this是JavaScript中的關(guān)鍵字之一,在編寫(xiě)程序的時(shí)候經(jīng)常會(huì)用到,正確的理解和使用關(guān)鍵字this尤為重要。首先必須要說(shuō)的是,this的指向在函數(shù)定義的時(shí)候是確定不了的,只有函數(shù)執(zhí)行的時(shí)候才能確定this到底指向誰(shuí),實(shí)際上this的最終指向的是那個(gè)調(diào)用它的對(duì)象(這

        this是JavaScript中的關(guān)鍵字之一,在編寫(xiě)程序的時(shí)候經(jīng)常會(huì)用到,正確的理解和使用關(guān)鍵字this尤為重要。首先必須要說(shuō)的是,this的指向在函數(shù)定義的時(shí)候是確定不了的,只有函數(shù)執(zhí)行的時(shí)候才能確定this到底指向誰(shuí),實(shí)際上this的最終指向的是那個(gè)調(diào)用它的對(duì)象(這句話有些問(wèn)題,后面會(huì)解釋為什么會(huì)有問(wèn)題,雖然網(wǎng)上大部分的文章都是這樣說(shuō)的,雖然在很多情況下那樣去理解不會(huì)出什么問(wèn)題,但是實(shí)際上那樣理解是不準(zhǔn)確的,所以在你理解this的時(shí)候會(huì)有種琢磨不透的感覺(jué)),那么接下來(lái)我會(huì)深入的探討這個(gè)問(wèn)題。

          為什么要學(xué)習(xí)this?如果你學(xué)過(guò)函數(shù)式編程,面向?qū)ο缶幊蹋悄憧隙ㄖ栏墒裁从玫模绻銢](méi)有學(xué)過(guò),那么暫時(shí)可以不用看這篇文章,當(dāng)然如果你有興趣也可以看看,畢竟這是js中必須要掌握的東西。

        例子1:

        按照我們上面說(shuō)的this最終指向的是調(diào)用它的對(duì)象,這里的函數(shù)a實(shí)際是被Window對(duì)象所點(diǎn)出來(lái)的,下面的代碼就可以證明。

        和上面代碼一樣吧,其實(shí)alert也是window的一個(gè)屬性,也是window點(diǎn)出來(lái)的。

        例子2:

          這里的this指向的是對(duì)象o,因?yàn)槟阏{(diào)用這個(gè)fn是通過(guò)o.fn()執(zhí)行的,那自然指向就是對(duì)象o,這里再次強(qiáng)調(diào)一點(diǎn),this的指向在函數(shù)創(chuàng)建的時(shí)候是決定不了的,在調(diào)用的時(shí)候才能決定,誰(shuí)調(diào)用的就指向誰(shuí),一定要搞清楚這個(gè)。

        其實(shí)例子1和例子2說(shuō)的并不夠準(zhǔn)確,下面這個(gè)例子就可以推翻上面的理論。

        如果要徹底的搞懂this必須看接下來(lái)的幾個(gè)例子

        例子3:

          這段代碼和上面的那段代碼幾乎是一樣的,但是這里的this為什么不是指向window,如果按照上面的理論,最終this指向的是調(diào)用它的對(duì)象,這里先說(shuō)個(gè)而外話,window是js中的全局對(duì)象,我們創(chuàng)建的變量實(shí)際上是給window添加屬性,所以這里可以用window點(diǎn)o對(duì)象。

          這里先不解釋為什么上面的那段代碼this為什么沒(méi)有指向window,我們?cè)賮?lái)看一段代碼。

          這里同樣也是對(duì)象o點(diǎn)出來(lái)的,但是同樣this并沒(méi)有執(zhí)行它,那你肯定會(huì)說(shuō)我一開(kāi)始說(shuō)的那些不就都是錯(cuò)誤的嗎?其實(shí)也不是,只是一開(kāi)始說(shuō)的不準(zhǔn)確,接下來(lái)我將補(bǔ)充一句話,我相信你就可以徹底的理解this的指向的問(wèn)題。

         情況1:如果一個(gè)函數(shù)中有this,但是它沒(méi)有被上一級(jí)的對(duì)象所調(diào)用,那么this指向的就是window,這里需要說(shuō)明的是在js的嚴(yán)格版中this指向的不是window,但是我們這里不探討嚴(yán)格版的問(wèn)題,你想了解可以自行上網(wǎng)查找。

          情況2:如果一個(gè)函數(shù)中有this,這個(gè)函數(shù)有被上一級(jí)的對(duì)象所調(diào)用,那么this指向的就是上一級(jí)的對(duì)象。

          情況3:如果一個(gè)函數(shù)中有this,這個(gè)函數(shù)中包含多個(gè)對(duì)象,盡管這個(gè)函數(shù)是被最外層的對(duì)象所調(diào)用,this指向的也只是它上一級(jí)的對(duì)象,例子3可以證明,如果不相信,那么接下來(lái)我們繼續(xù)看幾個(gè)例子。

        盡管對(duì)象b中沒(méi)有屬性a,這個(gè)this指向的也是對(duì)象b,因?yàn)閠his只會(huì)指向它的上一級(jí)對(duì)象,不管這個(gè)對(duì)象中有沒(méi)有this要的東西。

        還有一種比較特殊的情況,例子4:

        這里this指向的是window,是不是有些蒙了?其實(shí)是因?yàn)槟銢](méi)有理解一句話,這句話同樣至關(guān)重要。

          this永遠(yuǎn)指向的是最后調(diào)用它的對(duì)象,也就是看它執(zhí)行的時(shí)候是誰(shuí)調(diào)用的,例子4中雖然函數(shù)fn是被對(duì)象b所引用,但是在將fn賦值給變量j的時(shí)候并沒(méi)有執(zhí)行所以最終指向的是window,這和例子3是不一樣的,例子3是直接執(zhí)行了fn。

          this講來(lái)講去其實(shí)就是那么一回事,只不過(guò)在不同的情況下指向的會(huì)有些不同,上面的總結(jié)每個(gè)地方都有些小錯(cuò)誤,也不能說(shuō)是錯(cuò)誤,而是在不同環(huán)境下情況就會(huì)有不同,所以我也沒(méi)有辦法一次解釋清楚,只能你慢慢地的去體會(huì)。

        構(gòu)造函數(shù)版this:

          這里之所以對(duì)象a可以點(diǎn)出函數(shù)Fn里面的user是因?yàn)閚ew關(guān)鍵字可以改變this的指向,將這個(gè)this指向?qū)ο骯,為什么我說(shuō)a是對(duì)象,因?yàn)橛昧薾ew關(guān)鍵字就是創(chuàng)建一個(gè)對(duì)象實(shí)例,理解這句話可以想想我們的例子3,我們這里用變量a創(chuàng)建了一個(gè)Fn的實(shí)例(相當(dāng)于復(fù)制了一份Fn到對(duì)象a里面),此時(shí)僅僅只是創(chuàng)建,并沒(méi)有執(zhí)行,而調(diào)用這個(gè)函數(shù)Fn的是對(duì)象a,那么this指向的自然是對(duì)象,那么為什么對(duì)象Fn中會(huì)有user,因?yàn)槟阋呀?jīng)復(fù)制了一份Fn函數(shù)到對(duì)象a中,用了new關(guān)鍵字就等同于復(fù)制了一份。

          除了上面的這些以外,我們還可以自行改變this的指向,關(guān)于自行改變this的指向請(qǐng)看JavaScript中call,apply,bind方法的總結(jié)這篇文章,詳細(xì)的說(shuō)明了我們?nèi)绾问謩?dòng)更改this的指向。

        聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        靈活的理解JavaScript中的this指向_javascript技巧

        靈活的理解JavaScript中的this指向_javascript技巧:this是JavaScript中的關(guān)鍵字之一,在編寫(xiě)程序的時(shí)候經(jīng)常會(huì)用到,正確的理解和使用關(guān)鍵字this尤為重要。首先必須要說(shuō)的是,this的指向在函數(shù)定義的時(shí)候是確定不了的,只有函數(shù)執(zhí)行的時(shí)候才能確定this到底指向誰(shuí),實(shí)際上this的最終指向的是那個(gè)調(diào)用它的對(duì)象(這
        推薦度:
        標(biāo)簽: js 理解 javascript
        • 熱門(mén)焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門(mén)推薦

        專題
        Top
        主站蜘蛛池模板: 狠狠躁狠狠爱免费视频无码| 亚洲国产精品无码久久久秋霞1| 成人午夜影视全部免费看| 全免费一级毛片在线播放| 亚洲成在人线在线播放无码 | a级毛片无码免费真人久久| 亚洲中文字幕无码久久2017| XXX2高清在线观看免费视频| 亚洲中文字幕丝袜制服一区| 成人一区二区免费视频| 亚洲国产精品va在线播放 | 4444www免费看| 亚洲免费在线视频观看| 国产在线jyzzjyzz免费麻豆| 天堂亚洲国产中文在线| 国产无遮挡裸体免费视频| 免费大片av手机看片| 亚洲综合无码精品一区二区三区 | 中文字幕亚洲一区二区va在线| 男女拍拍拍免费视频网站| 久久久久亚洲Av片无码v| 免费成人福利视频| 亚洲中文字幕无码av| 日本一道高清不卡免费| sss日本免费完整版在线观看| 亚洲一区二区三区AV无码| 99爱视频99爱在线观看免费| 亚洲H在线播放在线观看H| 美女被免费视频网站a国产| av电影在线免费看| 亚洲国产综合精品中文第一区| 91成年人免费视频| 另类图片亚洲校园小说区| 亚洲av无码一区二区三区不卡| 毛片免费在线视频| 亚洲五月午夜免费在线视频| 久久亚洲精精品中文字幕| 免费观看午夜在线欧差毛片| 国产成人久久AV免费| 精品亚洲福利一区二区| 久久夜色精品国产亚洲|