js call() apply()

<strong>区分apply,call就一句话:</strong>
`foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments)==this.foo(arg1, arg2, arg3)`
<font size=1>call, apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例,也就是每个方法都有call, apply属性.既然作为方法的属性,那它们的使用就当然是针对方法的了.这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同.</font>

<strong>不同点:方法传递的参数不同</strong>
```
<script type="text/javascript">
		/*
		 * apply方法: 
		 * 语法:apply(thisObj,[argArray])
		 * 定义:应用某一对象的一个方法,用另一个对象替换当前对象。
		 */
			//定义一个人类
			function Person(name,age){
				this.name = name;
				this.age = age;
			}
			
			//定义一个学生类
			function Student(name,age,grade){
				Person.apply(this,arguments);
				//或者
				Person.call(this,name,age)
				this.grade = grade;
			}
			
			var student = new Student("dqf","20","一年级");
			console.info("name:"+student.name+"\n"+"age:"+student.age+"\n"+"grade:"+student.grade);
			
```
<font color=red>结果如下:<font>
      ![这里写图片描述](https://img-blog.csdn.net/20160628081004815)

```
var b = new B();
//给对象a动态指派b的setMessage方法,注意,a本身是没有这方法的!
//a的消息是setMessage()的参数列表
b.setMessage.call(a, "a的消息");
//下面将显示"a的消息"
alert(a.getMessage());
//给对象b动态指派a的getMessage方法,注意,b本身也是没有这方法的!

/*
	b.setMessage.call(a,"a的消息");
	其实就相当于a.setMessage("a"的消息)
	call, apply作用就是借用别人的方法来调用,就像调用自己的一样.
*/
```

<strong>call, apply方法区别是,从第二个参数起, call方法参数将依次传递给借用的方法作参数, 而apply直接将这些参数放到一个数组中再传递, 最后借用方法的参数列表是一样的.</strong>

部分资料来源:

> http://www.cnblogs.com/fighting_cp/archive/2010/09/20/1831844.html
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值