js中的call和apply函数。继承这样实现!
call方法JScript参考中的说明:调用一个对象的一个方法,以另一个对象替换当前对象。call([thisObj[,arg1[, arg2[, [,.argN]]]]]),但是没有示例
apply方法JScript参考中的说明:应用某一对象的一个方法,用另一个对象替换当前对象。apply([thisObj[,argArray]]) 。
个人做了测试得到如下结论:
1. 使用方式为:classA.call(obj,arg1,arg2,...),这就相当于调用了classA的构造函数,并把引用赋值给obj,arg1,arg2,...是可能的参数。
2. 如果obj是再调用call之前,已经是一个对象的引用(即不是null),那么调用call后,会把创建ClassA的对象,并且把之前obj对象的方法和属性合并到新创建的对象中,然后再赋给obj。这个最后得到令人兴奋的结论就是“继承”。即调用classA.call(obj,...)函数后,obj中的对象是ClassA继承于obj原来对象的类所得到的对象。
如:var obj = new BaseClass();
DriveClass.call(obj,...);
以上假设BaseClass和DriveClass是已经声明的类(function),那么执行后obj对象将拥有DriveClass和BaseClass的方法和属性,如果类成员名称存在冲突,那么DriveClass的会覆盖BaseClass的成员。产生的结果和类继承的结果一样!