JavaScript中有一个call和apply方法,其作用基本相同,但也有略微的区别。先来看看JS手册中对call的解释:
call方法调用一个对象的一个方法,以另一个对象替换当前对象。call([thisObj[,arg1[,arg2[,[,.argN]]]]])参数thisObj可选项。将被用作当前对象的对象。arg1,arg2,,argN可选项。将被传递方法参数序列。说明call方法可以用来代替另一个对象调用一个方法。call方法可将一个函数的对象上下文从初始的上下文改变为由thisObj指定的新对象。如果没有提供thisObj参数,那么Global对象被用作thisObj。说明白一点其实就是更改对象的内部指针,即改变对象的this指向的内容。这在面向对象的js编程过程中有时是很有用的。引用网上一个代码段,运行后自然就明白其道理。
可见分别弹出了func和var。到这里就对call的每个参数的意义有所了解了。
对于apply和call两者在作用上是相同的,但两者在参数上有区别的。对于第一个参数意义都一样,但对第二个参数:
apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。
如func.call(func1,var1,var2,var3)对应的apply写法为:func.apply(func1,[var1,var2,var3])同时使用apply的好处是可以直接将当前函数的arguments对象作为apply的第二个参数传入。
如下面代码所示:
functionprint(a,b,c,d){alert(a+b+c+d);}functionexample(a,b,c,d){//用call方式借用print,参数显式打散传递print.call(this,a,b,c,d);//用apply方式借用print,参数作为一个数组传递,//这里直接用JavaScript方法内本身有的arguments数组print.apply(this,arguments);//或者封装成数组print.apply(this,[a,b,c,d]);}//下面将显示”背光脚本”example(”背”,“光”,“脚”,“本”);最后一句由于直接调用example方法,所以在该方法中的上下文对象this就是window对象.
所以,call,apply方法它们除了第一个参数,即执行时上下文对象相同外,call方法的其它参数将依次传递给借用的方法作参数,而apply就两个参数,第二个参数为一个数组传递.所以可以说成
call,apply方法区别是,从第二个参数起,call方法参数将依次传递给借用的方法作参数,而apply直接将这些参数放到一个数组中再传递,最后借用方法的参数列表是一样的.