Javascript中關(guān)于this的用法

(轉(zhuǎn)載微信上看到的很棒的一篇關(guān)于this的寫法阴挣,分享給大家
http://mp.weixin.qq.com/s/ksqtCd8ouxU-cVc_HnA4Aw
也可以看阮一峰的這篇:
http://www.ruanyifeng.com/blog/2010/04/using_this_keyword_in_javascript.html
還有51博客上看到的很詳細(xì)的解釋:
http://weizhan.51cto.com/article/view/58eb2924f2dd872e48200541
相信這幾篇大家看看應(yīng)該會有更深入的理解局待。
你可能遇到過這樣的 JS 面試題:

var obj = {
  foo: function(){
    console.log(this)
  }
}

var bar = obj.foo
obj.foo() // 打印出的 this 是 obj
bar() // 打印出的 this 是 window

請解釋最后兩行函數(shù)的值為什么不一樣孵淘。

——-

初學(xué)者關(guān)于 this 的理解一直很模糊憨降。今天這篇文章就要一次講清楚了与殃。

而且這個解釋立帖,你在別的地方看不到眼溶。看懂這篇文章晓勇,所有關(guān)于 this 的面試題堂飞,都是小菜。

函數(shù)調(diào)用

首先需要從函數(shù)的調(diào)用開始講起绑咱。

JS(ES5)里面有三種函數(shù)調(diào)用形式:

func(p1, p2)
obj.child.method(p1, p2)
func.call(context, p1, p2) // 先不講 apply

一般绰筛,初學(xué)者都知道前兩種形式,而且認(rèn)為前兩種形式「優(yōu)于」第三種形式描融。

從看到這篇文章起铝噩,你一定要記住,第三種調(diào)用形式稼稿,才是正常調(diào)用形式:

func.call(context, p1, p2)

其他兩種都是語法糖薄榛,可以等價地變?yōu)?call 形式:

func(p1, p2) 等價于
func.call(undefined, p1, p2)

obj.child.method(p1, p2) 等價于
obj.child.method.call(obj.child, p1, p2)

請記下來。(我們稱此代碼為「轉(zhuǎn)換代碼」让歼,方便下文引用)

至此我們的函數(shù)調(diào)用只有一種形式:

func.call(context, p1, p2)

這樣敞恋,this 就好解釋了

this,就是上面代碼中的 context谋右。就這么簡單硬猫。

this 是你 call 一個函數(shù)時傳的 context,由于你從來不用 call 形式的函數(shù)調(diào)用改执,所以你一直不知道啸蜜。

先看 func(p1, p2) 中的 this 如何確定:

當(dāng)你寫下面代碼時

function func(){
 console.log(this)
}

func()

等價于

function func(){
 console.log(this)
}

func.call(undefined) // 可以簡寫為 func.call()

按理說打印出來的 this 應(yīng)該就是 undefined 了吧,但是瀏覽器里有一條規(guī)則:

如果你傳的 context 就 null 或者 undefined辈挂,那么 window 對象就是默認(rèn)的 context(嚴(yán)格模式下默認(rèn) context 是 undefined)
因此上面的打印結(jié)果是 window衬横。

如果你希望這里的 this 不是 window,很簡單:

func.call(obj) // 那么里面的 this 就是 obj 對象了

再看 obj.child.method(p1, p2) 的 this 如何確定

var obj = {
 foo: function(){
   console.log(this)
 }
}

obj.foo()

按照「轉(zhuǎn)換代碼」终蒂,我們將 obj.foo() 轉(zhuǎn)換為

obj.foo.call(obj)

好了蜂林,this 就是 obj。搞定拇泣。

回到題目:

var obj = {
 foo: function(){
   console.log(this)
 }
}

var bar = obj.foo
obj.foo() // 轉(zhuǎn)換為 obj.foo.call(obj)噪叙,this 就是 obj
bar()
// 轉(zhuǎn)換為 bar.call()
// 由于沒有傳 context
// 所以 this 就是 undefined
// 最后瀏覽器給你一個默認(rèn)的 this —— window 對象

[ ] 語法

function fn (){ console.log(this) }
var arr = [fn, fn2]
arr0 // 這里面的 this 又是什么呢?

我們可以把 arr0 想象為arr.0( )霉翔,雖然后者的語法錯了睁蕾,但是形式與轉(zhuǎn)換代碼里的 obj.child.method(p1, p2) 對應(yīng)上了,于是就可以愉快的轉(zhuǎn)換了:

arr0
假想為 arr.0()
然后轉(zhuǎn)換為 arr.0.call(arr)
那么里面的 this 就是 arr 了 :)

總結(jié)

this 就是你 call 一個函數(shù)時,傳入的 context子眶。
如果你的函數(shù)調(diào)用形式不是 call 形式瀑凝,請按照「轉(zhuǎn)換代碼」將其轉(zhuǎn)換為 call 形式。

以后你遇到所有跟 this 有關(guān)的筆試題壹店,都不會有疑問了猜丹。

完。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末硅卢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子藏杖,更是在濱河造成了極大的恐慌将塑,老刑警劉巖,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蝌麸,死亡現(xiàn)場離奇詭異点寥,居然都是意外死亡,警方通過查閱死者的電腦和手機来吩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進(jìn)店門敢辩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人弟疆,你說我怎么就攤上這事戚长。” “怎么了怠苔?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵同廉,是天一觀的道長。 經(jīng)常有香客問我柑司,道長迫肖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任攒驰,我火速辦了婚禮蟆湖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘玻粪。我一直安慰自己隅津,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布奶段。 她就那樣靜靜地躺著饥瓷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪痹籍。 梳的紋絲不亂的頭發(fā)上呢铆,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天,我揣著相機與錄音蹲缠,去河邊找鬼棺克。 笑死悠垛,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的娜谊。 我是一名探鬼主播确买,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼纱皆!你這毒婦竟也來了湾趾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤派草,失蹤者是張志新(化名)和其女友劉穎搀缠,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體近迁,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡艺普,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了鉴竭。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片歧譬。...
    茶點故事閱讀 40,928評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖搏存,靈堂內(nèi)的尸體忽然破棺而出瑰步,到底是詐尸還是另有隱情,我是刑警寧澤祭埂,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布面氓,位于F島的核電站,受9級特大地震影響蛆橡,放射性物質(zhì)發(fā)生泄漏舌界。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一泰演、第九天 我趴在偏房一處隱蔽的房頂上張望呻拌。 院中可真熱鬧,春花似錦睦焕、人聲如沸藐握。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽猾普。三九已至,卻和暖如春本谜,著一層夾襖步出監(jiān)牢的瞬間初家,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留溜在,地道東北人陌知。 一個月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像掖肋,于是被迫代替她去往敵國和親仆葡。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,937評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 目標(biāo):js中this的指向? 問題的引出 指出this指向什么 js中函數(shù)的三種調(diào)用形式 func(p1, p2)...
    放風(fēng)箏的小小馬閱讀 226評論 0 0
  • 原文: https://github.com/ecomfe/spec/blob/master/javascript...
    zock閱讀 3,377評論 2 36
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法志笼,類相關(guān)的語法沿盅,內(nèi)部類的語法,繼承相關(guān)的語法纫溃,異常的語法嗡呼,線程的語...
    子非魚_t_閱讀 31,669評論 18 399
  • 妖族吃貨閱讀 279評論 5 4
  • 人死了之后靈魂會變成鳥,它保留生前的習(xí)慣皇耗,會停留在最在意的人身邊。 如果對方?jīng)]有認(rèn)出來揍很,半年后郎楼,靈魂永遠(yuǎn)消散。 ...
    簡葬一傘閱讀 844評論 0 1