类式继承对于大部分开发者来说都已经熟悉,只要有了带方法(method)的类(class)就可以把他们实例化(instantiate)为对象. 下面就有一个简单的方法来模拟类式继承.代码清单如下: <script> //辅助函数 定义
Function.prototype.method = function( name,func ){ this.prototype[name] = func; return this; } //实现函数 Function.method('inherits', function(parent){ //记录我们目前所在父层次的级数 var depth = 0; //继承父对象的方法 var proto = this.prototype = new parent(); //特权函数 this.method('uber', function uber(name){ var func; var ret; var v = parent.prototype; //如果我们已经在某个 'uber' 函数之内 if(depth){ for (var i=d; i>0;i+=1) { v = v.constructor.prototype; }; //从该prototype中或得函数 func = v[name]; } else{ //从prototype获得要执行的函数 func = prototype[name]; //如果此函数属于当前的prototype if( func == this[name]){ //则改为调用父对象的prototype func = v[name]; } } //记录我们在继承堆栈中所在位置的级数 depth += 1; // ret = func.apply(this,Array.prototype.slice.apply(arguments,[1])); //恢复继承堆栈 depth -= 1; return ret; }); return this; }) //只继承父对象特定函数的函数 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; } //实现的例子 Person.method('getName', function(){ return name; }) function User( name, password ){ this.name = name; this.password = password; } User.inherits( Person ); </script>
下面重点讲解一下,上面的三个函数 1.Function.prootype.method:它提供了一个简单的方法,把函数与构造函数的原型关联起来;之所以有效,是因为所有的构造函数本身都是函数,所以能获得"method"这个新方法; 来自:小贺 2.Function.prototype.inherite: 这一函数可以提供简单的对象继承,他的代码主要围绕在任意方法中调用this.uber('methodName')为中心,并在让这个uber方法去执行他要覆盖的父对象.这是javascript继承模型中并未内建的部分. 3. Functon.prototype.swiss:这是.method()函数的增强版,可以用于从单一父对象获取多个函数.如果用在多个父对象上就能能获得可用的多对象继承.
|