簡單的JS多重繼承示例
更新時間:2008年03月13日 22:16:25 作者:
JS多重繼承實例,js新手學(xué)習(xí)資料
復(fù)制代碼 代碼如下:
$defined = function (v) {
return v != undefined;
}
Class = function () {
var base = {};
for (var k=0; k<arguments.length; k++) {
//{{new arguments[k]() with custom constructor field.
var o = arguments[k].prototype;
o.constructor = arguments[k];
arguments[k].call(o);
//}}
for (key in o) base[key] = o[key];
}
function Klass () {
// for every class one object cache.
var clso = null;
function klass() {
if (arguments.length<=0 && clso!=null) {
// hit cache.
return clso;
}
if ($defined(this.constructor.init)) {
// use init() for class initialization.
this.constructor.init.apply(this, arguments);
}
clso = this;
}
klass.prototype = base;
return klass;
}
return Klass();
}
A = new Class();
A.init = function () {
this.x = 400;
this.y = 300;
}
B = new Class(A);
B.init = function () {
this.y = 200;
this.z = 100;
}
C = new Class(B);
C.init = function () {
this.z = 0;
}
c = new C();
alert(c.x);
alert(c.y);
alert(c.z);
您可能感興趣的文章:
相關(guān)文章
JavaScript defineProperty如何實現(xiàn)屬性劫持
雙向數(shù)據(jù)綁定的核心方法,主要是做數(shù)據(jù)劫持操作(監(jiān)控數(shù)據(jù)變化),下面這篇文章主要給大家介紹了關(guān)于JavaScript defineProperty如何實現(xiàn)屬性劫持的相關(guān)資料,需要的朋友可以參考下2021-07-07JavaScript function函數(shù)種類詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript function函數(shù)種類,包括普通函數(shù)、匿名函數(shù)、閉包函數(shù),感興趣的小伙伴們可以參考一下2016-02-02javascript實現(xiàn)回車鍵提交表單方法總結(jié)
這篇文章主要介紹了javascript實現(xiàn)回車鍵提交表單方法,實例總結(jié)了純javascript與jQuery的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-01-01js 關(guān)于=+與+=日期函數(shù)使用說明(賦值運(yùn)算符)
js 關(guān)于=+與+=日期函數(shù)使用說明(賦值運(yùn)算符),可以看下,就是一些運(yùn)算符的使用,看哪個更適合你。2011-11-11