这篇文章主要为大家详细介绍了Javascript的类继承探讨,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编罗X来看看吧。
/**
* @param
* @arrange (512.笔记) www.q1010.com
**/
function A() {
}
A.prototype.a1 = function() { };
function B() {
}
B.prototype = new A();
B.prototype.b1 = function() { };
var b = new B();
alert(b.constructor == A); // true
alert(b.constructor == B); // false
这段代码的主要问题是:
/**
* @param
* @arrange (512.笔记) www.q1010.com
**/
function A(s1, s2) {
this.totalLength = s1.length + s2.length;
}
A.prototype.a1 = function() {
};
function B(s1, s2) {
}
B.prototype = new A();
B.prototype.b1 = function() {
};
new B("ab", "123");
可以看到,这段代码中根本没有办法把s1和s2传到A,而又因为实例化A作为B的原型时没有参数,所以出现了异常:
/**
* @param
* @arrange (512.笔记) www.q1010.com
**/
function B(s1, s2) {
A.apply(this, arguments);
alert(this.totalLength);
}
接下来的问题就是如何把A的方法添加到B的原型中去。这也不难,只要遍历A.prototype,把方法复制到B.prototype即可。要注意的是,对于同名的方法,自然是子类优先(重载),因而不能覆盖: JS代码如下:
/**
* @param
* @arrange (512.笔记) www.q1010.com
**/
for (var m in A.prototype) {
if (!B.prototype[m]) { // 父类不能覆盖子类的方法
B.prototype[m] = A.prototype[m];
}
}
本文来自:http://www.q1010.com/174/1638-0.html
注:关于Javascript的类继承探讨的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:继承
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。