1、call和apply的说明app
一、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,由于属于Function.prototype,因此每一个Function对象实例(就是每一个方法)都有call,apply属性。既然做为方法的属性,那它们的使用就固然是针对方法的了,这两个方法是容易混淆的,由于它们的做用同样,只是使用方式不一样。函数
二、语法:foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments) == this.foo(arg1, arg2, arg3);this
三、相同点:两个方法产生的做用是彻底同样的。spa
四、不一样点:方法传递的参数不一样。prototype
2、实例代码code
function A(){ this.flag = 'A'; this.tip = function(){ console.log(this.flag); }; } function B(){ this.flag = 'B'; } var a = new A(); var b = new B(); a.tip.call(b);//B a.tip.apply(b);//B
代码解释(即说明apply和call做用)对象
一、实例代码定义了两个函数A和B,A中包含flag属性和tip属性(这个属性赋值一个函数),B中有一个flag属性。blog
二、分别建立A和B的对象a和b。ip
三、不管是a.tip.call(b);和a.tip.apply(b);运行的结果都是弹出B。io
四、从结果中能够看出call和apply均可以让B对象调用A对象的tip方法,而且修改了this的当前做用对象。