this

1.apply赶掖、call 有什么作用露筒,什么區(qū)別

函數(shù)調(diào)用有三種形式:
func(p1,p2)
obj.childrend.method(p1,p2)
func.call(context,p1,p2)
第三種形式才是正常調(diào)用形式,call就是調(diào)用函數(shù)的一種形式甸鸟,call的第一個參數(shù)(context)很重要,context就是函數(shù)執(zhí)行的上下文環(huán)境,也就是this。call一個函數(shù)時傳入的context是什么励稳,函數(shù)的this就指向什么。如果傳入的context是null或者undefined囱井,那么context默認(rèn)就是window(嚴(yán)格模式下默認(rèn) context 是 undefined)
apply也是調(diào)用函數(shù)的一種形式驹尼,和call不同之處在于apply調(diào)用是只能傳入兩個參數(shù).apply(context,參數(shù)數(shù)組),.call(context,p1,p2)可傳入多個參數(shù)庞呕。


2.下面代碼輸出什么新翎,為什么
func() 

function func() { 
  alert(this)
}

func()等價于func.call()
輸出的內(nèi)容是window全局對象


3.以下代碼輸出什么?
var john = { 
  firstName: "John" 
}
function func() { 
  alert(this.firstName + ": hi!")
}
john.sayHi = func
john.sayHi() 

john.sayHi()可寫成john.sayHi.call(john),這里call傳入的context是john這個對象,所以this.firstNme的值是'John',打印結(jié)果是John :hi


4.下面代碼輸出什么
function fn0(){
    function fn(){
        console.log(this);
    }
    fn();
}

fn0();

document.addEventListener('click', function(e){
    console.log(this);
    setTimeout(function(){
        console.log(this);
    }, 200);
}, false);

fn0()執(zhí)行后打印的this是全局對象window住练,因?yàn)閒n0()執(zhí)行的時候是window在調(diào)用地啰。
事件綁定后第一次打印的this是觸發(fā)該事件的dom對象,第二次打印的this是window全局對象讲逛,因?yàn)閟etTimeout和setInterval執(zhí)行時也是window全局對象在調(diào)用髓绽。


5.下面代碼輸出什么,為什么
var john = { 
  firstName: "John" 
}

function func() { 
  alert( this.firstName )
}
func.call(john) 

.call(context)這里context代表傳入的函數(shù)執(zhí)行的上下文環(huán)境妆绞,這里傳入的是john對象顺呕,所以func.call(john)打印的內(nèi)容是John


6.代碼輸出?
var john = { 
  firstName: "John",
  surname: "Smith"
}

function func(a, b) { 
  alert( this[a] + ' ' + this[b] )
}
func.call(john, 'firstName', 'surname') 

func.call(context,參數(shù)1,參數(shù)2) 這里函數(shù)執(zhí)行時傳入的this是john對象括饶,所以打印的內(nèi)容是John Smith


7.以下代碼有什么問題株茶,如何修改
var module= {
  bind: function(){
    $btn.on('click', function(){
      console.log(this) //this指什么
      this.showMsg();
    })
  },
  
  showMsg: function(){
    console.log('饑人谷');
  }
}

console.log(this)打印的內(nèi)容是觸發(fā)綁定事件的DOM對象,這里是$btn觸發(fā)所以this指向$btn图焰。代碼中執(zhí)行this.showMsg()會報錯启盛,因?yàn)閠his指向$btn后,$btn上沒有.showMsg()這個方法,.showMsg()方法在module對象上僵闯。修改代碼如下

var module= {
  bind: function(){
  var cur=this//申明cur卧抗,將this賦值給cur,這里this指向module對象
    $btn.on('click', function(){
      console.log(this) //綁定事件后this在這里指向$btn
      cur.showMsg();//cur指向module對象
    })
  },

  showMsg: function(){
    console.log('饑人谷');
  }
}

8.下面代碼輸出什么
var length = 3;
function fa() {
  console.log(this.length);
}
var obj = {
  length: 2,
  doSome: function (fn) {
    fn();
    arguments[0]();
  }
}
obj.doSome(fa)

obj.doSome(fa)等價于
obj.doSome.call(obj,fa)鳖粟,注意雖然這里this指向obj社裆,但參數(shù)2位置上是fa函數(shù),doSome定義傳入?yún)?shù)并執(zhí)行'fn()'向图,所以參數(shù)2位置上的fa()要執(zhí)行泳秀,fa()等價于fa.call(null),因?yàn)閚ull所以this指向全局對象window,因?yàn)閘ength=3實(shí)在全局對象下聲明的,所以第一次打印結(jié)果為3.
執(zhí)行arguments[0]()時榄攀,等價于arguments[0].call(arguments)由于arguments是類數(shù)組對象嗜傅,相當(dāng)于傳入的第0個參數(shù)執(zhí)行,這里傳入的第0個參數(shù)是fa,所以等價于fa.call(arguments),這時候this指向arguments類數(shù)組對象檩赢,arguments.length=1吕嘀,因?yàn)橹挥?個參數(shù)fa(),所以第二次打印1


9.下面代碼輸出什么? why
obj = {
  go: function() { alert(this) }
}
obj.go(); 
(obj.go)(); 
(a = obj.go)(); 
(0 || obj.go)(); 

1.obj.go()等價于obj.go.call(obj) this指向obj贞瞒,所以打印obj對象
2.(obj.go)()相當(dāng)于obj對象上的go屬性立即執(zhí)行币他,go是個函數(shù)所以等價于obj.go.call(obj)打印obj對象
3.obj.go賦值給全局對象a,等價于a=function(){alert(this)}憔狞,a()---->a.call(),這里打印的是window全局對象
4.注意這里執(zhí)行或運(yùn)算函數(shù)時蝴悉,是全局對象window在調(diào)用,因?yàn)榈谝粋€0不成立所以等價于obj.go.call()瘾敢。所以打印window全局對象

****本文版權(quán)歸本人和饑人谷所有拍冠,轉(zhuǎn)載請注明來源。****

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末簇抵,一起剝皮案震驚了整個濱河市庆杜,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌碟摆,老刑警劉巖晃财,帶你破解...
    沈念sama閱讀 218,640評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異典蜕,居然都是意外死亡断盛,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評論 3 395
  • 文/潘曉璐 我一進(jìn)店門愉舔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钢猛,“玉大人,你說我怎么就攤上這事轩缤∶酰” “怎么了贩绕?”我有些...
    開封第一講書人閱讀 165,011評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長壶愤。 經(jīng)常有香客問我淑倾,道長,這世上最難降的妖魔是什么征椒? 我笑而不...
    開封第一講書人閱讀 58,755評論 1 294
  • 正文 為了忘掉前任娇哆,我火速辦了婚禮,結(jié)果婚禮上陕靠,老公的妹妹穿的比我還像新娘。我一直安慰自己脱茉,他們只是感情好剪芥,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著琴许,像睡著了一般税肪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上榜田,一...
    開封第一講書人閱讀 51,610評論 1 305
  • 那天益兄,我揣著相機(jī)與錄音,去河邊找鬼箭券。 笑死净捅,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的辩块。 我是一名探鬼主播蛔六,決...
    沈念sama閱讀 40,352評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼废亭!你這毒婦竟也來了国章?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,257評論 0 276
  • 序言:老撾萬榮一對情侶失蹤豆村,失蹤者是張志新(化名)和其女友劉穎液兽,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體掌动,經(jīng)...
    沈念sama閱讀 45,717評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡四啰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了粗恢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拟逮。...
    茶點(diǎn)故事閱讀 40,021評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖适滓,靈堂內(nèi)的尸體忽然破棺而出敦迄,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,735評論 5 346
  • 正文 年R本政府宣布罚屋,位于F島的核電站苦囱,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜娱仔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評論 3 330
  • 文/蒙蒙 一渔欢、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧羹铅,春花似錦、人聲如沸愉昆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,936評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽跛溉。三九已至焊切,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間芳室,已是汗流浹背专肪。 一陣腳步聲響...
    開封第一講書人閱讀 33,054評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留堪侯,地道東北人嚎尤。 一個月前我還...
    沈念sama閱讀 48,224評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像伍宦,于是被迫代替她去往敵國和親诺苹。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評論 2 355

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

  • 簡答題 1.apply雹拄、call 有什么作用收奔,什么區(qū)別 call apply,調(diào)用一個函數(shù)滓玖,傳入函數(shù)執(zhí)行上下文及參...
    GarenWang閱讀 549評論 1 4
  • 問答 apply坪哄、call 有什么作用,什么區(qū)別势篡? 在介紹apply和call之前翩肌,我們先來看看this,this...
    小木子2016閱讀 278評論 0 0
  • javascript里的this指針邏輯上的概念也是實(shí)例化對象,這一點(diǎn)和java語言里的this指針是一致的碍侦,但是...
    天外來人閱讀 466評論 0 0
  • 與其他語言相比粱坤,函數(shù)的this關(guān)鍵字在JavaScript中的表現(xiàn)略有不同隶糕,此外,在嚴(yán)格模式和非嚴(yán)格模式之間也會有...
    codingC閱讀 574評論 0 0
  • 昨天一直在趕非文學(xué)翻譯的presentation ppt站玄,差不多十二點(diǎn)才睡覺枚驻,躺在床上時又過了一下要點(diǎn)評的內(nèi)容,輾...
    敏哥兒閱讀 736評論 0 1