最近更新
阅读排行
关注本站

浅析call和apply

阅读:6128 次   编辑日期:2013-11-27

目录:

概述:

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

call方法:

call方法:调用一个对象的一个方法,以另一个对象替换当前对象。
调用方法:call([thisObj,obj1,obj2....])
看下面的例子:
	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]])
看下面的例子:
    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来实现了,也就是直接指定参数列表对应值的位置。
将本篇文章分享到:
top