欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入淺出聊一聊js中的'this'關(guān)鍵字

 更新時(shí)間:2022年07月12日 15:04:58   作者:航航不脫發(fā)  
js中的this關(guān)鍵字平時(shí)在開發(fā)中使用時(shí)倒是也能正常應(yīng)用,但是對其使用和判斷并不能信手拈來,所以下面這篇文章主要給大家介紹了關(guān)于js中this關(guān)鍵字的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在JavaScript中‘this’關(guān)鍵字是一個(gè)非常重要的概念,然而許多的初學(xué)者們發(fā)現(xiàn)深度的理解它卻又十分困難,如果你正在或者將要被this折磨,那么現(xiàn)在深呼吸放輕松點(diǎn),你必須得知道實(shí)際上去理解‘this’這個(gè)關(guān)鍵字并不難;耐心的看完本文,相信你對‘this’會(huì)有更深的理解。下面我們將一起來討論‘this’關(guān)鍵字的工作原理。

什么是'this'關(guān)鍵字

'this'關(guān)鍵字是為每個(gè)執(zhí)行上下文(每個(gè)函數(shù))創(chuàng)建的一個(gè)特殊變量;所以一般來說,在使用'this'關(guān)鍵字的函數(shù)中,'this'永遠(yuǎn)是取其所有者的值。換句話的意思就是它指向該函數(shù)的所有者。這樣聽起來很抽象吧,那么你現(xiàn)在只要記住'this'關(guān)鍵字的值不是靜態(tài)的,所以它總是不一樣。它的值取決于函數(shù)是怎么被調(diào)用的,只有在實(shí)際調(diào)用函數(shù)時(shí)才分配它的值。就比如我們將x=4;那么x的值就是4,但是'this'關(guān)鍵字的值取決于函數(shù)的調(diào)用方式;所以現(xiàn)在我們來分析四種不同的調(diào)用函數(shù)的方式。

四種方式---1.調(diào)用函數(shù)的第一種方法是:將函數(shù)作為一種方法

Example: this代表一個(gè)對象

const bruce={
    name:'bruce',
    birthYear:2001,
    calcAge:function () {
        return 2022-this.birthYear
    }
};
console.log(bruce.calcAge());//21`

在上面的bruce對象里面有一個(gè)calcAge()函數(shù),這個(gè)函數(shù)是一個(gè)被附加到了bruce對象里面的函數(shù)。所以當(dāng)我們調(diào)用一個(gè)方法的時(shí)候,calcAge()里面的this將會(huì)指向這個(gè)對象;換句話來說,this所指的bruce這個(gè)對象正在調(diào)用這個(gè)方法。在代碼的最后一行,我們調(diào)用了這個(gè)函數(shù);在calcAge()函數(shù)里面我們使用了this,那么這個(gè)this的值應(yīng)該是什么呢?沒錯(cuò),這個(gè)this指的是bruce;所以this.birrhYear==bruce.birthYear==2001。

四種方式---2.調(diào)用函數(shù)的第二種方法是: 簡單的調(diào)用函數(shù),不將函數(shù)作為方法,不附加到任何對象里面

Example: 此時(shí)this=undefined

const calcAge=function(birthYear){
    console.log(2022-birthYear);
    //查看此函數(shù)中的this
    console.log(this);
}
calcAge(2001)

結(jié)果如下:

像這樣常規(guī)的調(diào)用某個(gè)函數(shù),只是簡單的調(diào)用某個(gè)函數(shù),并沒有將這個(gè)函數(shù)添加到任何對象上面;可以這樣說這個(gè)this沒有主人,就是this指的就是window 。但是在嚴(yán)格模式下全局對象無法進(jìn)行默認(rèn)綁定,所以導(dǎo)致this只能綁定在undefined上。這就是this的默認(rèn)綁定規(guī)則:

  • this所處的詞法作用域在哪里生效this就綁定在哪里。
  • 在嚴(yán)格模式下,全局對象無法進(jìn)行默認(rèn)綁定,所以導(dǎo)致this只能綁定在undefined上

四種方式---3.調(diào)用函數(shù)的第三種方法是:調(diào)用箭頭函數(shù)

箭頭函數(shù)沒有自己的this關(guān)鍵字

Example:

//3.箭頭函數(shù)的調(diào)用
const calcAge= birthYear => {
    console.log(2022-birthYear);
    //查看此函數(shù)中的this
    console.log(this);
}
calcAge()

執(zhí)行結(jié)果:

因?yàn)榧^函數(shù)沒有this,所以在箭頭函數(shù)里面的this是它外層作用域里面的非箭頭函數(shù)的this,而本例中外層作用域是window,所以這里的this指的是window

四種方式---4.調(diào)用函數(shù)的第四種方式:該函數(shù)被調(diào)用作為事件監(jiān)聽器

那么此時(shí)的this將會(huì)指向處理程序函數(shù)所附加到的DOM元素

深入理解this指向的是調(diào)用該方法的對象

這就意味著this關(guān)鍵字不會(huì)簡單的指向在我們編寫方法的對象上面。

在第一種函數(shù)調(diào)用的方式中,因?yàn)閎ruce是調(diào)用calaAge()方法的對象,所以此時(shí)this是bruce; 那么現(xiàn)在創(chuàng)建一個(gè)新對象:

const lucy={
   birthYear:2006,
}

我們都知道函數(shù)只是一個(gè)值,所以我們可以這樣:

const lucy={
    birthYear:2006,
}
lucy.calcAge=bruce.calcAge
console.log(lucy);

結(jié)果:

現(xiàn)在lucy里面也有了一個(gè)calcAge()方法,我們再來執(zhí)行l(wèi)ucy.calcAge()

const lucy={
    birthYear:2006,
}
lucy.calcAge=bruce.calcAge
console.log(lucy);
lucy.calcAge()

結(jié)果為:

這就說明lucy對象調(diào)用calcAge()方法時(shí),此時(shí)函數(shù)calcAge()方法里面的this指向的是lucy, 即調(diào)用該方法的對象。所以this關(guān)鍵字如上面所說,它不是靜態(tài)的,而是取決于函數(shù)的調(diào)用方式。

現(xiàn)在我們來定義一個(gè)常量y,并將bruce.calcAge()函數(shù)賦給它

const y=bruce.calcAge
y()

結(jié)果為:

那么此時(shí)y()只是作為一個(gè)普通函數(shù)來進(jìn)行調(diào)用,this是window

小結(jié)

this關(guān)鍵字是一個(gè)讓許多初學(xué)者感到困惑的東西,但是總的來說:

1.如果函數(shù)是以普通函數(shù)(非構(gòu)造函數(shù))的形式調(diào)用,this指的永遠(yuǎn)都是window

2.如果函數(shù)是以方法的形式調(diào)用,this就是調(diào)用方法的那個(gè)對象

總結(jié)

到此這篇關(guān)于js中this關(guān)鍵字的文章就介紹到這了,更多相關(guān)js中this關(guān)鍵字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 微信小程序scroll-view組件實(shí)現(xiàn)滾動(dòng)動(dòng)畫

    微信小程序scroll-view組件實(shí)現(xiàn)滾動(dòng)動(dòng)畫

    這篇文章主要為大家詳細(xì)介紹了微信小程序scroll-view組件實(shí)現(xiàn)滾動(dòng)動(dòng)畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • js中async函數(shù)結(jié)合promise的小案例淺析

    js中async函數(shù)結(jié)合promise的小案例淺析

    這篇文章主要介紹了js中async函數(shù)結(jié)合promise的小案例淺析,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • 微信小程序?qū)崿F(xiàn)簡易加法計(jì)算器

    微信小程序?qū)崿F(xiàn)簡易加法計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了微信小程序加法計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 談?wù)凧avaScript自定義回調(diào)函數(shù)

    談?wù)凧avaScript自定義回調(diào)函數(shù)

    使用Jquery的時(shí)候發(fā)現(xiàn)它里面的很多方法都提供回調(diào)函數(shù),接下來通過本篇文章給大家介紹js自定義回調(diào)函數(shù),需要的朋友參考下
    2015-10-10
  • javascript遞歸函數(shù)定義和用法示例分析

    javascript遞歸函數(shù)定義和用法示例分析

    這篇文章主要介紹了javascript遞歸函數(shù)定義和用法示例分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • JS實(shí)現(xiàn)判斷碰撞的方法

    JS實(shí)現(xiàn)判斷碰撞的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)判斷碰撞的方法,實(shí)例分析了通過js判斷實(shí)體碰撞的技巧與相關(guān)應(yīng)用,需要的朋友可以參考下
    2015-02-02
  • JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶名存儲(chǔ)案例

    JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶名存儲(chǔ)案例

    本文主要介紹了JavaScript本地存儲(chǔ)實(shí)現(xiàn)用戶名存儲(chǔ)案例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 詳解JS構(gòu)造函數(shù)中this和return

    詳解JS構(gòu)造函數(shù)中this和return

    本文通過實(shí)例代碼給大家介紹了JS構(gòu)造函數(shù)中this和return,需要的朋友參考下吧
    2017-09-09
  • uni-app中使用手機(jī)號(hào)一鍵登錄的詳細(xì)圖文教程

    uni-app中使用手機(jī)號(hào)一鍵登錄的詳細(xì)圖文教程

    最近剛接觸了uni-app,用于開發(fā)微信小程序,設(shè)計(jì)到了微信授權(quán)登錄,下面這篇文章主要給大家介紹了關(guān)于uni-app中使用手機(jī)號(hào)一鍵登錄的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • js 輸入框 正則表達(dá)式(菜鳥必看教程)

    js 輸入框 正則表達(dá)式(菜鳥必看教程)

    下面小編就為大家?guī)硪黄猨s輸入框使用正則表達(dá)式校驗(yàn)輸入內(nèi)容的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02

最新評論