javascript 写类方式之四
javascript 写类方式之四
发布时间:2017-01-14 来源:查字典编辑
摘要:4、构造函数+原型直接组装一个类;同一构造函数将组装出同一类型通过前面几篇得知javascript写类无非基于构造函数和原型。既然这样,我们...

4、构造函数 + 原型 直接组装一个类;同一构造函数将组装出同一类型

通过前面几篇得知javascript写类无非基于构造函数 和原型 。既然这样,我们写个工具函数来写类。

复制代码 代码如下:

/**

* $class 写类工具函数之一

* @param {Object} constructor

* @param {Object} prototype

*/

function $class(constructor,prototype) {

var c = constructor || function(){};

var p = prototype || {};

c.prototype = p;

return c;

}

嗯。工具类写好了,来组装下:用构造函数来生成类实例的属性(字段),原型对象用来生成类实例的方法。

复制代码 代码如下:

//构造函数

function Person(name) {

this.name = name;

}

//原型对象

var proto = {

getName : function(){return this.name},

setName : function(name){this.name = name;}

}

//组装

var Man = $class(Person,proto);

var Woman = $class(Person,proto);

ok,这时候已经得到了两个类Man,Woman。并且是同一个类型的。测试如下:

复制代码 代码如下:

console.log(Man == Woman);//true

console.log(Man.prototype == Woman.prototype);//true

创建对象看看,

复制代码 代码如下:

var man = new Man("Andy");

var woman = new Woman("Lily");

console.log(man instanceof Man);//true

console.log(woman instanceof Woman);//true

console.log(man instanceof Person);//true

console.log(woman instanceof Person);//true

ok一切如我们所期望。但是有个问题,下面代码的结果输出false,

复制代码 代码如下:

console.log(man.constructor == Person);//false

这让人不悦:从以上的代码看出man的确是通过Man类new出来的 var man = new Man("Andy"),那么对象实例man的构造器应该指向Man,但为何事与愿违呢?

原因就在于$class中重写了Person的原型:c.prototype = p;

好了,我们把$class稍微改写下,将方法都挂在构造器的原型上(而不是重写构造器的原型),如下:

复制代码 代码如下:

function $class(constructor,prototype) {

var c = constructor || function(){};

var p = prototype || {};

// c.prototype = p;

for(var atr in p)

c.prototype[atr] = p[atr];

return c;

}

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类