javascript中的this詳解
This對(duì)象在js中就一直是個(gè)坑貨,很難判斷它到底指向什么,而我們由于來自C++或者python的self的經(jīng)驗(yàn),又常常會(huì)犯這一類的錯(cuò)誤。接下來就詳細(xì)地講一下this對(duì)象的歸屬。
rule1:全局環(huán)境的this
javascript的環(huán)境天生就由函數(shù)來決定,在js里不能通過代碼塊隔開上下文,不被函數(shù)所包裹的環(huán)境就是全局環(huán)境,全局環(huán)境中的this就指向全局變量window,看下面一個(gè)例子
var name='jjj';
console.log(this.name);
//會(huì)成功輸出jjj
rule2:作為方法調(diào)用時(shí)的this
顯然這種情況很好判斷,與python里的self是一致的,this毫無疑問指向調(diào)用方法的對(duì)象
var user={
name:'kkk'
};
user.getName=function(){
console.log(this.name);
};
user.getName();
//會(huì)輸出kkk
rule3:作為構(gòu)造函數(shù)時(shí)的this
這時(shí)的this也不用我多說,顯然是指向新創(chuàng)建的對(duì)象,構(gòu)造函數(shù)的運(yùn)行其實(shí)并不創(chuàng)建對(duì)象,而僅僅是初始化,對(duì)象在運(yùn)行之前就已經(jīng)被創(chuàng)建
下面還是舉例說明
function User(name){
this.name=name;
}
var f1=new User('kkk');
var f2=User('kkk');
console.log(f1.name);//kkk
console.log(f2.name);//undefined沒有name屬性
rule4:間接調(diào)用中的this
所謂間接調(diào)用是指利用apply和call來調(diào)用函數(shù),這時(shí)的this指向它們參數(shù)列表中的第一個(gè)參數(shù)。
var setName=function(name){
this.name=name;
};
var user={level:2};
user.apply(setName,'jjj');
console.log(user.name);//jjj
rule5:其他情況中的this
記住其他情況下this均不會(huì)被改變,這里也是最容易犯錯(cuò)的地方。
var name = "clever coder";
var person = {
name : "foocoder",
hello : function(sth){
var sayhello = function(sth) {
console.log(this.name + " says " + sth);
};
sayhello(sth);
}
}
person.hello("hello world");//clever coder says hello world
上面的代碼看起來很奇怪,難道this不應(yīng)該指向person嗎?
我們應(yīng)該記住被嵌套的函數(shù)中的this是不會(huì)指向嵌套它的函數(shù),在這個(gè)例子里面就是sayhello中的this不會(huì)指向hello對(duì)應(yīng)的那個(gè)函數(shù)。如果我們把例子稍稍改一下變成
hello:function(sth){
console.log(this.name + " says " + sth);
}
//foocoder says hello world
大家應(yīng)該已經(jīng)看明白了,這個(gè)時(shí)候,sayhello并非在作為方法調(diào)用,所以this指向全局對(duì)象。。。
這時(shí)候問題來了,用node運(yùn)行最初的例子會(huì)顯示undefined says hello world,不知道有沒有大神講解一下。
rule6:eval破壞所有規(guī)則
最后以一個(gè)例子結(jié)束
var name = "clever coder";
var user={
name:'kkk'
};
user.getName=function(){
console.log(this.name);
};
var get=user.getName;
get();//clever coder
大家是否明白了?
相關(guān)文章
JS實(shí)現(xiàn)控制表格內(nèi)指定單元格內(nèi)容對(duì)齊的方法
這篇文章主要介紹了JS實(shí)現(xiàn)控制表格內(nèi)指定單元格內(nèi)容對(duì)齊的方法,涉及javascript操作表格單元格內(nèi)容樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03微信小程序scroll-view橫向滑動(dòng)嵌套for循環(huán)的示例代碼
這篇文章主要介紹了微信小程序scroll-view橫向滑動(dòng)嵌套for循環(huán)的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09js中eval()函數(shù)和trim()去掉字符串左右空格應(yīng)用
對(duì)于js中eval()函數(shù)的理解和寫一個(gè)函數(shù)trim()去掉字符串左右空格;對(duì)于js中eval()函數(shù)的理解是本人心得不一定正確,感興趣的朋友參考下,或許對(duì)你學(xué)習(xí)eval()函數(shù)有所幫助2013-02-02解決JSON.parse轉(zhuǎn)化不規(guī)范json字符串的問題
這篇文章主要介紹了解決JSON.parse轉(zhuǎn)化不規(guī)范json字符串的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09javascript 定義初始化數(shù)組函數(shù)
有段javascript代碼很困惑,經(jīng)過不斷的查資料,終于弄懂了!呵呵!2009-09-09一道優(yōu)雅面試題分析js中fn()和return fn()的區(qū)別
這篇文章主要帶領(lǐng)大家深入理解JavaScript中 fn() 和 return fn() 的區(qū)別,感興趣的小伙伴們可以參考一下2016-07-07