obj.call(thisObj, arg1, arg2, ...);
obj.apply(thisObj, [arg1, arg2, ...]);
call和apply做用都是把obj绑定到thisObj的做用,即改变this的指向,然而惟一的区别就是apply传递的参数必须得是数组的形式传递,而call则直接连续参数传递数组
当一个对象须要调用另一个对象里面的方法的时候就能够用到call和apply,call和Apply能够理解成是继承另一个对象的方法,如下代码举例:app
首先,咱们先创建两个对象,obj1和obj2this
var name = "全局中的name"; var obj1 = { name:"obj1中的name", func1:function(){ console.log(this.name); }, func2:function (a,b) { console.log(a+b); return a+b; } } var obj2 = { name:"obj2中的name" }
若是obj2对象要调用obj1中的func1方法,则code
obj1.func1.call(obj2); //输出:obj2中的name obj1.func1.apply(obj2);//输出:obj2中的name
call和apply第一个参数都是表示obj1绑定的对象,若是obj1要绑定到this,此时obj1就是绑定到全局,如:对象
obj1.func1.call(this);//输出:全局中的name obj1.func1.apply(this);//输出:全局中的name
若是obj2对象要调用obj1中的func2方法,则继承
obj1.func2.call(obj2,1,2);//输出:3 obj1.func2.apply(obj2,[1,2]);//输出:3
此时func2方法是有参数的,call和apply中第二个参数开始是传给func2方法的参数,可是call参数是直接连续传递,而apply传递参数是以一个数组传递io
所有代码展现:console
var name = "全局中的name"; var obj1 = { name:"obj1中的name", func1:function(){ console.log(this.name); }, func2:function (a,b) { console.log(a+b); return a+b; } } var obj2 = { name:"obj2中的name" } obj1.func1.call(this);//输出:全局中的name obj1.func1.apply(this);//输出:全局中的name obj1.func1.call(obj2); //输出:obj2中的name obj1.func1.apply(obj2);//输出:obj2中的name obj1.func2.call(obj2,1,2);//输出:3 obj1.func2.apply(obj2,[1,2]);//输出:3