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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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的第二个参数传入,不需要转化。

以上是关于js基于伪装的继承call()方法和apply()方法的主要内容,如果未能解决你的问题,请参考以下文章

js call()和apply()方法的区别和用法详解

JS中Call() and Apply()

JS面向对象 -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

js中的call()和apply()方法

转载:JS call()方法和apply()方法

JS中的call()方法和apply()方法用法总结