首页 > 代码库 > 浅析call和apply

浅析call和apply

概述:

今天我们讲一个在咱们工作中不经常用,但是却在面试中经常被问到的方法:call方法和apply方法。

call方法:

call方法:调用一个对象的一个方法,以另一个对象替换当前对象。
调用方法:call([thisObj,obj1,obj2....])
看下面的例子:
1
2
3
4
5
6
7
8
9
10
function add(a,b)
{
    alert(a+b);
}
function sub(a,b)
{
    alert(a-b);
}
 
add.call(sub,3,1);//4
结果是“4”,call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。 说的在直白点,上面例子中,把add放到了sub中执行,所以a+b = 4。 如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法:

apply方法的意思和call差不多,唯一的区别就是传递的参数是个数组。
调用方法:call([thisObj,[argArray]])
看下面的例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function test1(name,age)
    {
        this.name=name;
        this.age=age;
    }
/*定义一个学生类*/
function test2(name,age,grade)
    {
        test1.apply(this,arguments);
        this.grade=grade;
    }
//创建一个学生类
var test3=new test2("uw3c",24,"一年级");
//测试
alert("name:"+test3.name+"\n"+"age:"+test3.age+"\n"+"grade:"+test3.grade);
大家肯定会惊奇的发现,
this:在创建对象在这个时候代表的是student
arguments:是一个数组,也就是["uw3c","24",”一年级”];
也就是通俗一点讲就是:用test3去执行test1这个类里面的内容,在test1这个类里面存在this.name等之类的语句,这样就将属性创建到了test3对象里面
 

什么时候用call方法、apply方法:

在给对象参数的情况下,如果参数的形式是数组的时候,比如apply示例里面传递了参数arguments, 这个参数是数组类型,并且在调用test1的时候参数的列表是对应一致的(也就是test1和test2的参数列表前两位是一致的) 就可以采用 apply , 如果我的test1的参数列表是这样的(age,name),而test2的参数列表是(name,age,grade),这样就可以用call来实现了,也就是直接指定参数列表对应值的位置。

浅析call和apply