call与apply

作用

call与apply这2个方法,都能改变this指向。

 

例子

call与apply最大的用处,就是用来继承。

function Person(name,age){
    this.name = name;
    this.age = age;
    this.printMsg = function(){
        alert('my name is :' + this.name + ', my age is :' + this.age);
    }
}

function Men(name,age){
    Person.call(this,name,age);
}

var m1 = new Men('tom', '18');
var m2 = new Men('marry', '25');
m1.printMsg();
m2.printMsg();

有一个父类Person和一个子类Men。父类拥有的属性,子类拥也想有。这时候就可以用call与apply。

当我们new一个Men对象的时候,首先会执行Person.call(this,name,age);这句话。然后Men类会去把Person拥有的变量和方法都

拷贝一份给自己。

Person.call(this,name,age); 这句代码的功能相当于这样 :

function Men(name,age){
    this.name = name;
    this.age = age;
    this.printMsg = function(){
        alert('my name is :' + this.name + ', my age is :' + this.age);
    }
}

 

call与apply异同

相同点 :都能改变this指向

异同点 :call从第二个参数开始,可以接受无数个参数,每个参数都会映射到父类的变量中。apply第二个参数规定是一个数组,

数组中的每个参数也会映射到父类的变量中。所以如果上面的例子,我们用apply来实现的话,可以这样写 :

function Person(name,age){
    this.name = name;
    this.age = age;
    this.printMsg = function(){
        alert('my name is :' + this.name + ', my age is :' + this.age);
    }
}

function Men(name,age){
    Person.apply(this,[name,age]); //就这里不同
    this.name = name;
    this.age = age;
    this.printMsg = function(){
        alert('my name is :' + this.name + ', my age is :' + this.age);
    }
}

var m1 = new Men('tom', '18');
var m2 = new Men('marry', '25');
m1.printMsg();
m2.printMsg();

ps :需要注意的是,用这种方式来实现继承有个缺点,函数都不是共享的。比如我们可以打印

alert(m1.printMsg === m2.printMsg)

此时的结果是false

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值