Javascript中this的用法詳解
前些日子面試的時(shí)候用到了this,面試官說(shuō)我的理解有點(diǎn)偏差,回來(lái)看了下書和一些博客,做了點(diǎn)測(cè)試,發(fā)現(xiàn)自己的理解的確有誤
1.全局變量
應(yīng)該是最常用的吧,函數(shù)中調(diào)用一個(gè)this,這里其實(shí)就是全局變量
var value="0"; function mei(){ var value="1"; console.log(this.value); //0 console.log(value); //1 } mei();
輸出0就是因?yàn)閠his指向的是全局
2.構(gòu)造函數(shù)
這是我比較熟悉的用法,構(gòu)造函數(shù)中用this,new一個(gè)新的對(duì)象后this就指向了這個(gè)新的對(duì)象
var value="window"; function mei(){ this.value=1; this.show=function(){ console.log(this.value) } } var m=new mei(); console.log(m.value); //1 m.show(); //1
可以看到輸出的是1而并不是window,可見由于構(gòu)造函數(shù),這里的this已經(jīng)指向新的對(duì)象了而不是全局變量
3.call和apply
直接借用我的call和apply的博客中的例子
var p="456"; function f1(){ this.p="123"; } function f2() { console.log(this.p); } f2(); //456 f2.call(f1()); //123 f2.apply(f1()); //123
第一行輸出456很好理解,this指向全局,后面的123是因?yàn)槭褂昧薱all或者apply后,f2中的this指向了f1,而f1中的p為123,具體解釋直接戳那篇博文
4.函數(shù)作為某個(gè)對(duì)象的方法調(diào)用(我出錯(cuò)的地方)
當(dāng)時(shí)讓我寫一個(gè)對(duì)象有幾個(gè)方法,我腦子一抽定義了個(gè)全局變量,然后在對(duì)象的方法里用this調(diào)用,面試官問(wèn)我這個(gè)this是什么?我說(shuō)應(yīng)該是window,因?yàn)檫@種方式我用的少,以為只有new或者call才會(huì)改變this的指向,他就說(shuō)不對(duì),讓我回去自己看看,現(xiàn)在試了試,我還真是錯(cuò)了,貼代碼
var value="father"; function mei(){} mei.value="child"; mei.get=function(){console.log(this.value)}; mei.show=function(){console.log(value)}; mei.get(); //child mei.show(); //father
由于get是作為mei的方法調(diào)用的,因此這里的this指向了mei.value所以輸出child
至于father我是這樣理解的,show指向的函數(shù)是定義在全局環(huán)境下的,由于作用域鏈,在show中沒(méi)有找到value,于是就去定義他的環(huán)境中找,這就找到了全局的value,如果這里有理解錯(cuò)誤的話希望有朋友可以指出來(lái)!
相關(guān)文章
JavaScript字符串對(duì)象replace方法實(shí)例(用于字符串替換或正則替換)
這篇文章主要介紹了JavaScript字符串對(duì)象replace方法實(shí)例,replace方法用于字符串替換,同時(shí)支持正則表達(dá)式替換,需要的朋友可以參考下2014-10-10javascript學(xué)習(xí)筆記(五)正則表達(dá)式
正則表達(dá)式在web開發(fā)中會(huì)經(jīng)常用到,主要用于驗(yàn)證用戶輸入的數(shù)據(jù)的格式。2011-04-04關(guān)于session和cookie的簡(jiǎn)單理解
下面小編就為大家?guī)?lái)一篇關(guān)于session和cookie的簡(jiǎn)單理解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06JS數(shù)學(xué)函數(shù)Exp使用說(shuō)明
JS數(shù)學(xué)函數(shù)Exp使用說(shuō)明2012-08-08JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)教程
這篇文章主要介紹了JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)入門教程,包括對(duì)節(jié)點(diǎn)的創(chuàng)建修改刪除等操作,還特別提到了其中appendChild()與insertBefore()插入節(jié)點(diǎn)時(shí)需注意的問(wèn)題,需要的朋友可以參考下2016-03-03javascript學(xué)習(xí)筆記(六)數(shù)據(jù)類型和JSON格式
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式,我們稱之為JavaScript對(duì)象表示法。使用JSON進(jìn)行數(shù)據(jù)傳輸?shù)膬?yōu)勢(shì)之一是JSON實(shí)際上就是JavaScript。它基于ECMAScript第3版中JavaScript對(duì)象字面量語(yǔ)法子集的一種文本格式。2014-10-10