javascript中call,apply,bind的用法對(duì)比分析
關(guān)于call,apply,bind這三個(gè)函數(shù)的用法,是學(xué)習(xí)javascript這門語(yǔ)言無(wú)法越過(guò)的知識(shí)點(diǎn)。下邊我就來(lái)好好總結(jié)一下它們?nèi)吒髯缘挠梅?,及常?jiàn)的應(yīng)用場(chǎng)景。
首先看call這個(gè)函數(shù),可以理解成"借用“,"請(qǐng)求"。想像一下如下的情景:你孤單一人漂泊在外,有急事想往家里打電話,可是很不巧,手機(jī)欠費(fèi)了,或者沒(méi)電了,或者掉坑里了,總之你的手機(jī)就是用不成??墒悄惴谴蜻@個(gè)電話不可,于是你可以去借一下朋友的手機(jī),或者借用一下鄰居的手機(jī),或者公用電話,這樣呢,你就可以在自己沒(méi)有手機(jī)可用的情況下,完成打電話這個(gè)事情,而至于你是用誰(shuí)的電話打的,就不重要了,反正和用你自己的手機(jī)打的電話是一樣的效果。call這個(gè)函數(shù)的初衷也和這個(gè)類似,下面我用代碼來(lái)模擬一下它的應(yīng)用情景:
var frog = { name : 'frog', say : function(){ alert(this.name); } } var rabbit = { name : 'rabbit' } frog.say.call(rubbit) // rabbit
rubbit這個(gè)對(duì)象是個(gè)啞吧,但是他想要說(shuō)出自己的名字,光憑它自己的能力,是不可能實(shí)現(xiàn)的,好在呢,它有一個(gè)叫frog的好基友,它可以說(shuō)話。于是呢,rubbit就請(qǐng)求frog替它實(shí)現(xiàn)這個(gè)心愿。frog.say.call()的第一個(gè)參數(shù),一定是要填寫發(fā)出請(qǐng)求的人,律師喜歡稱為委托人。這里是rubbit請(qǐng)求frog替它say名字,所以填寫rubbit。這樣一來(lái),在say的時(shí)候,就會(huì)查找rubbit的name,而不是frog的name了。如果這里填寫frog會(huì)是什么樣子呢?這就好比是自己請(qǐng)求自己做某事,喂自己代鹽也是可以的??梢栽囈幌拢?br />
var frog = { name : 'frog', say : function(){ alert(this.name); } } var rabbit = { name : 'rabbit' } frog.say.call(frog) // frog
自己喂自己袋鹽,肯定是說(shuō)自己的名字啦,這完全沒(méi)有什么意外的。下面我們來(lái)看看call的經(jīng)典用法:
//把參數(shù)轉(zhuǎn)化成真正的數(shù)組對(duì)象 function frog(){ var arr = [].slice.call(arguments); console.log(arguments.slice,arr.slice) // undefined function slice() { [native code] } } frog(1,2,3,4)
能過(guò)這么一call,我們就可以把a(bǔ)rguments對(duì)象當(dāng)成數(shù)組對(duì)象來(lái)使用了。關(guān)于call的用法很多,翻開(kāi)jquery的源碼,很容易就能找到很多運(yùn)用的地方。在此不一一列舉了,還是回到我們前面的情景,借電話這種事太簡(jiǎn)單了,打完電話,肯定還想捎點(diǎn)什么東西回去,畢竟這么多年漂泊在外,沒(méi)有好好孝敬下老人,買點(diǎn)當(dāng)?shù)氐奶禺a(chǎn)回去,肯定是極好的??墒峭膺叺纳顗毫κ侨绱酥?,每天除了上班還要加班,如果請(qǐng)假的話,不但工資要扣,還要花費(fèi)不少的路費(fèi),這些錢加起來(lái),估計(jì)都?jí)蚶先嗽诩依镆荒甑挠枚攘恕O胂氩粍澦?,于是又想到call這個(gè)函數(shù),請(qǐng)它幫忙,順道帶回去是非常明智的選擇,而且它不收費(fèi),不限量,不限重,有多少,帶多少。我再次用代碼來(lái)演示一下:
var frog = { name : 'frog', send : function(money,food,milk,suagate){ alert(money+food+milk+suagate); } } var rabbit = { name : 'rabbit' } frog.send.call(rubbit,'money','food','milk','suagate')
如果你有錢任性,甚至可以把iphone6 plus什么的也寄幾個(gè)回去。.^_^.
說(shuō)到這里call就差不多結(jié)束了,我也不知道上面的情景劇,是不是讓你明白了call是怎么回事,如果只是勾起了你的思鄉(xiāng)之情,那我表示抱歉。
call還有一個(gè)同父異母的兄弟,叫apply,如果弄明白了call的用法,那么apply其實(shí)也是一回事,唯一的區(qū)別呢,就是apply不喜歡傳東西的時(shí)候,一個(gè)東西打一個(gè)包,顯得很麻煩不說(shuō),還不環(huán)保。于是他就提供一個(gè)裝東西的大箱子,你把你要傳的東西全放在它提供的箱子里就好了。這個(gè)大箱子,就是一個(gè)數(shù)組。上面的例子,用apply來(lái)做的話,就是這樣子的:
var frog = { name : 'frog', send : function(money,food,milk,suagate){ alert(money+food+milk+suagate); } } var rabbit = { name : 'rabbit' } //注意參數(shù)的區(qū)別 frog.send.apply(rubbit,['money','food','milk','suagate'])
以上就是apply,call的前世今生了。可是萬(wàn)萬(wàn)沒(méi)想到,apply和call的爸爸,前些年搞房地產(chǎn)發(fā)了財(cái),在外邊還有一個(gè)叫bind 的私生子。雖然比call和apply這兩個(gè)哥哥晚出道幾年,但是能力也不容小視。只不過(guò),他的身份,在某些地方,是不承認(rèn)的。比如IE6。下面我還是用代碼來(lái)演示下他的本領(lǐng):
var name = 'rubbit'; var frog = { name : 'frog', say : function(){ setTimeout(function(money,milk){ alert(this.name+money+milk) }.bind(this,'money','milk'),1000) } } frog.say();
通過(guò)對(duì)比發(fā)現(xiàn),bind可以直接連在function(){}后面用。相當(dāng)于把call 和 apply 都省了,直接在函數(shù)后面指定委托人和要傳遞的參數(shù)。從傳參的風(fēng)格上來(lái)說(shuō),更像call一些。
關(guān)于bind ,我們?cè)賮?lái)看一段經(jīng)典的用法:
var obj = { name : 'frog' } document.addEventListener('click',function(){ alert(this.name); // frog }.bind(obj),false);
總結(jié)一下,apply,call,bind,這三兄弟的相同點(diǎn)是:
1. 第一個(gè)參數(shù)都是邦定作用域,即是在誰(shuí)的地盤上做事。
2. 都可以傳遞參數(shù)
不同點(diǎn)是:
apply,call 兼容性更好,bind某些低版本的瀏覽器不支持。
apply 傳遞的參數(shù)必須是用數(shù)組進(jìn)行包裝的,而 call 和 bind 則是將要傳遞的參數(shù)一一列出。
大家是否對(duì)call,apply,bind三個(gè)函數(shù)的用法有了更深入的認(rèn)識(shí)了呢,希望本文能對(duì)大家有所幫助。
- JS中改變this指向的方法(call和apply、bind)
- js apply/call/caller/callee/bind使用方法與區(qū)別分析
- 詳解JS中的this、apply、call、bind(經(jīng)典面試題)
- 淺談javascript中call()、apply()、bind()的用法
- 跟我學(xué)習(xí)javascript的call(),apply(),bind()與回調(diào)
- 深入理解JavaScript中的call、apply、bind方法的區(qū)別
- Javascript中call,apply,bind方法的詳解與總結(jié)
- javascript中apply、call和bind的使用區(qū)別
- javascript中call apply 與 bind方法詳解
- 使用JS簡(jiǎn)單實(shí)現(xiàn)apply、call和bind方法的實(shí)例代碼
相關(guān)文章
js函數(shù)中onmousedown和onclick的區(qū)別和聯(lián)系探討
了解這兩個(gè)事件的區(qū)別,但是實(shí)際并沒(méi)有使用到這兩個(gè)事件的區(qū)別去做一些操作,通常使用onclick的時(shí)候也可以使用onmousedown,使用onclick的時(shí)候更多一些2013-05-05JavaScript中關(guān)于indexOf的使用方法與問(wèn)題小結(jié)
indexOf方法的作用是:根據(jù)給定參數(shù)x返回目標(biāo)字符串(可以看成字符的數(shù)組)或數(shù)組中與x相等的項(xiàng)的索引。2010-08-08表單的焦點(diǎn)順序tabindex和對(duì)應(yīng)enter鍵提交
表單的焦點(diǎn)tab鍵順序:tabindex決定,如果值缺省,擇按順序一一對(duì)應(yīng),想詳細(xì)了解此功能應(yīng)用的朋友可以參考下2013-01-01javascript學(xué)習(xí)筆記(一) 在html中使用javascript
javascript學(xué)習(xí)筆記之在html中使用javascript 的方法,需要的朋友可以參考下2012-06-06window.requestAnimationFrame是什么意思,怎么用
window.requestAnimationFrame 告訴瀏覽器您要執(zhí)行的動(dòng)畫并且請(qǐng)求瀏覽器的在下一個(gè)動(dòng)畫幀重繪窗口,方法在瀏覽器重繪之前作為一個(gè)回調(diào)函數(shù)被調(diào)用,就是告訴瀏覽器在刷新屏幕的時(shí)候,調(diào)用這個(gè)方法2013-01-01Javascript數(shù)組Array基礎(chǔ)介紹
本文主要是給大家簡(jiǎn)單介紹了Array的相關(guān)基礎(chǔ)知識(shí),到這里也算是能對(duì)Array有更全面的理解了,希望大家能夠喜歡,后續(xù)我們將繼續(xù)介紹關(guān)于array的內(nèi)容。2016-03-03js關(guān)于字符長(zhǎng)度限制的問(wèn)題示例探討
字符長(zhǎng)度限制在某些特殊的使用場(chǎng)合還是比較實(shí)用的,下面為大家用示例探討下,感興趣的朋友可以參考下2014-01-01js中一維數(shù)組和二位數(shù)組中的幾個(gè)問(wèn)題示例說(shuō)明
這篇文章主要介紹了js中一維數(shù)組和二位數(shù)組中的幾個(gè)問(wèn)題,并給出對(duì)應(yīng)的解決方法,需要的朋友可以參考下2014-07-07