码迷,mamicode.com
首页 > 移动开发 > 详细

js中的call和apply方法的区别

时间:2016-05-04 15:47:55      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:

一、call和apply的说明

1、call,apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例(就是每个方法)都有call,apply属性。既然作为方法的属性,那它们的使用就当然是针对方法的了,这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同。

2、语法:foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments) == this.foo(arg1, arg2, arg3);

3、相同点:两个方法产生的作用是完全一样的。

4、不同点:方法传递的参数不同。

二、实例代码

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作用)

1、实例代码定义了两个函数A和B,A中包含flag属性和tip属性(这个属性赋值一个函数),B中有一个flag属性。

2、分别创建A和B的对象a和b。

3、无论是a.tip.call(b);和a.tip.apply(b);运行的结果都是弹出B。

4、从结果中可以看出call和apply都可以让B对象调用A对象的tip方法,并且修改了this的当前作用对象。

 

js中的call和apply方法的区别

标签:

原文地址:http://www.cnblogs.com/naokr/p/5458608.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!