- 相關(guān)推薦
關(guān)于javascript中apply()和call()方法的區(qū)別
如果沒(méi)接觸過(guò)動(dòng)態(tài)語(yǔ)言,以編譯型語(yǔ)言的思維方式去理解javaScript將會(huì)有種神奇而怪異的感覺(jué),因?yàn)橐庾R(shí)上往往不可能的事偏偏就發(fā)生了,甚至覺(jué)得不可理喻.如果在學(xué)JavaScript這自由而變幻無(wú)窮的語(yǔ)言過(guò)程中遇到這種感覺(jué),那么就從現(xiàn)在形始,請(qǐng)放下的您的”偏見(jiàn)”,因?yàn)檫@對(duì)您來(lái)說(shuō)絕對(duì)是一片新大陸。好了,不給大家嘮嗑了,言歸正傳吧,先給大家講下apply和call方法的定義。
具體內(nèi)容如下所示:
方法定義
call, apply都屬于Function.prototype的一個(gè)方法,它是JavaScript引擎內(nèi)在實(shí)現(xiàn)的,因?yàn)閷儆贔unction.prototype,所以每個(gè)Function對(duì)象實(shí)例,也就是每個(gè)方法都有call, apply屬性.既然作為方法的屬性,那它們的使用就當(dāng)然是針對(duì)方法的了.這兩個(gè)方法是容易混淆的,因?yàn)樗鼈兊淖饔靡粯?只是使用方式不同.
call方法:
語(yǔ)法:call([thisObj[,arg1[, arg2[, [,.argN]]]]])
定義:調(diào)用一個(gè)對(duì)象的一個(gè)方法,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。
說(shuō)明:
call 方法可以用來(lái)代替另一個(gè)對(duì)象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象。
如果沒(méi)有提供 thisObj 參數(shù),那么 Global 對(duì)象被用作 thisObj。
apply方法:
語(yǔ)法:apply([thisObj[,argArray]])
定義:應(yīng)用某一對(duì)象的一個(gè)方法,用另一個(gè)對(duì)象替換當(dāng)前對(duì)象。
說(shuō)明:
如果 argArray 不是一個(gè)有效的數(shù)組或者不是 arguments 對(duì)象,那么將導(dǎo)致一個(gè) TypeError。
如果沒(méi)有提供 argArray 和 thisObj 任何一個(gè)參數(shù),那么 Global 對(duì)象將被用作 thisObj, 并且無(wú)法被傳遞任何參數(shù)
call, apply作用就是借用別人的方法來(lái)調(diào)用,就像調(diào)用自己的一樣.
它們的不同之處:
apply:最多只能有兩個(gè)參數(shù)——新this對(duì)象和一個(gè)數(shù)組 argArray。如果給該方法傳遞多個(gè)參數(shù),則把參數(shù)都寫進(jìn)這個(gè)數(shù)組里面,當(dāng)然,即使只有一個(gè)參數(shù),也要寫進(jìn)數(shù)組里面。如果 argArray 不是一個(gè)有效的數(shù)組或者不是 arguments 對(duì)象,那么將導(dǎo)致一個(gè) TypeError。如果沒(méi)有提供 argArray 和 thisObj 任何一個(gè)參數(shù),那么 Global 對(duì)象將被用作 thisObj, 并且無(wú)法被傳遞任何參數(shù)。
call:則是直接的參數(shù)列表,主要用在js對(duì)象各方法互相調(diào)用的時(shí)候,使當(dāng)前this實(shí)例指針保持一致,或在特殊情況下需要改變this指針。如果沒(méi)有提供 thisObj 參數(shù),那么 Global 對(duì)象被用作 thisObj。
更簡(jiǎn)單地說(shuō),apply和call功能一樣,只是傳入的參數(shù)列表形式不同:如 func.call(func1,var1,var2,var3)對(duì)應(yīng)的apply寫法為:
func.apply(func1,[var1,var2,var3])
如:
add.apply(sub,[3,1]);//add.call(sub,3,1);var a={n:1,m:2,add:function(){return this.n+this.m;}}var b={n:3,m:4}console.log(a.add.call(b));//b.n+b.m=7function Animal(){ this.name = "Animal"; this.showName = function(){ alert(this.name); } }function Cat(){ this.name = "Cat"; } var animal = new Animal(); var cat = new Cat(); //通過(guò)call或apply方法,將原本屬于Animal對(duì)象的showName()方法交給對(duì)象cat來(lái)使用了。 //輸入結(jié)果為"Cat" animal.showName.call(cat,","); animal.showName.apply(cat,[]);
以上內(nèi)容是小編給大家介紹的apply和call方法定義及apply和call方法的區(qū)別,希望大家喜歡。
【javascript中apply()和call()方法的區(qū)別】相關(guān)文章:
Javascript中arguments對(duì)象的詳解和使用方法08-20
詳解JavaScript中的splice()使用方法08-20
JavaScript類定義原型方法的兩種實(shí)現(xiàn)的區(qū)別07-11
內(nèi)外賬的區(qū)別和記賬方法07-10
JavaScript常用方法匯總10-25
javascript編程異常處理的方法08-04