|
類式繼承對于大部分開發(fā)者來說都已經(jīng)熟悉,只要有了帶方法(method)的類(class)就可以把他們實例化(instantiate)為對象.
下面就有一個簡單的方法來模擬類式繼承.代碼清單如下:
<script>
//輔助函數(shù) 定義Function.prototype.method = function( name,func ){
this.prototype[name] = func;
return this;
}
//實現(xiàn)函數(shù)
Function.method('inherits', function(parent){
//記錄我們目前所在父層次的級數(shù)
var depth = 0;
//繼承父對象的方法
var proto = this.prototype = new parent();
//特權函數(shù)
this.method('uber', function uber(name){
var func;
var ret;
var v = parent.prototype;
//如果我們已經(jīng)在某個 'uber' 函數(shù)之內(nèi)
if(depth){
for (var i=d; i>0;i+=1) {
v = v.constructor.prototype;
};
//從該prototype中或得函數(shù)
func = v[name];
}
else{
//從prototype獲得要執(zhí)行的函數(shù)
func = prototype[name];
//如果此函數(shù)屬于當前的prototype
if( func == this[name]){
//則改為調(diào)用父對象的prototype
func = v[name];
}
}
//記錄我們在繼承堆棧中所在位置的級數(shù)
depth += 1;
//
ret = func.apply(this,Array.prototype.slice.apply(arguments,[1]));
//恢復繼承堆棧
depth -= 1;
return ret;
});
return this;
})
//只繼承父對象特定函數(shù)的函數(shù)
Function.method('swiss',function(parent){
for (var i=1; i<arguments.length; i++) {
var name = arguments[i];
//將此方法導入this對象的prototype
this.prototype[name] = parent.prototype[name];
};
return this;
})
function Person( name ){
this.name = name;
}
//實現(xiàn)的例子
Person.method('getName', function(){
return name;
})
function User( name, password ){
this.name = name;
this.password = password;
}
User.inherits( Person );
</script>
it知識庫:Js中的類式繼承,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。