js基于伪装的继承call()方法和apply()方法

function class1()

{

   this.name = function(){

    alert("class1的方法name()");

   }

}

 function class2()

{

 class1.call(this);//要想实现class2继承class1 this就是当前对象class2。

}

 现在可以知道是否实现继承了:

 var cl = new class2();

 cl.name();//class2继承了class1,class2是父类。调用父类的方法

注意到,call()与apply()的区别:功能一样。第二个参数形式不一样。call传递多个参数,是任意形式。apply第二个参数必须是数组形式。

用代码来理解它们区别最好:

 a.call(b,2,3); ==>  a.apply(b,[2,3]);//数组形式传入

  就是利用了apply参数是数组的特性。结合函数的隐性参数,都会自动保存在arguments数组中。这样,使用apply的方式:

 this.initialize.apply(this, arguments);

 可以直接将当前函数的arguments数组作为apply的第二个参数传入,不需要转化。

转载于:https://www.cnblogs.com/huagnchucai/p/5974084.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值