关于javascript中apply和call方法的区别
2016-12-16 · 智游教育IT培训的黄埔军校
call和apply的说明
1、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例(就是每个方法)都有call,apply属性。既然作为方法的属性,那它们的使用就当然是针对方法的了,这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同。
2、语法:foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments) == this.foo(arg1, arg2, arg3);
3、相同点:两个方法产生的作用是完全一样的。
4、不同点:方法传递的参数不同。
二、实例代码
复制代码 代码如下:
<script type="text/javascript"> function A(){ this.flag = 'A'; this.tip = function(){ alert(this.flag); }; } function B(){ this.flag = 'B'; } var a = new A(); var b = new B(); //a.tip.call(b); a.tip.apply(b);</script>
三、代码解释(即说明apply和call作用)
1、实例代码定义了两个函数A和B,A中包含flag属性和tip属性(这个属性赋值一个函数),B中有一个flag属性。
2、分别创建A和B的对象a和b。
3、无论是a.tip.call(b);和a.tip.apply(b);运行的结果都是弹出B。
4、从结果中可以看出call和apply都可以让B对象调用A对象的tip方法,并且修改了this的当前作用对象。
2016-04-20 · 百度知道合伙人官方认证企业
function foobar(a, b, c, d) {}
可以这样调用:
foobar.call(thisObj, 1, 2, 3, 4)
或者
foobar.call(thisObj, [1, 2, 3, 4])
也就是说,call和apply只有调用的时候有差异,call是将要调用函数的参数作为call的参数依次传递,而apply是将要调用函数的参数作为apply的第二个参数作为数组传递。