javascript 写类方式之五_js面向对象
程序员文章站
2023-12-28 14:21:04
...
5、用 构造函数+原型 定义一个类;同一构造函数可以定义出多个类型
/**
* $define 写类工具函数之二
* @param {Object} constructor
* @param {Object} prototype
*/
function $define(constructor,prototype) {
var c = constructor || function(){};
var p = prototype || {};
return function() {
for(var atr in p)
arguments.callee.prototype[atr] = p[atr];
c.apply(this,arguments);
}
}
与第四种方式类似,仍然用构造函数,原型对象,定义两个类。
//构造函数
function Person(name) {
this.name = name;
}
//原型对象
var proto = {
getName : function(){return this.name},
setName : function(name){this.name = name;}
}
//定义两个类
var Man = $define(Person,proto);
var Woman = $define(Person,proto);
console.log(Man == Woman);//false,同一个构造函数(Person)定义不同的类
复制代码 代码如下:
/**
* $define 写类工具函数之二
* @param {Object} constructor
* @param {Object} prototype
*/
function $define(constructor,prototype) {
var c = constructor || function(){};
var p = prototype || {};
return function() {
for(var atr in p)
arguments.callee.prototype[atr] = p[atr];
c.apply(this,arguments);
}
}
与第四种方式类似,仍然用构造函数,原型对象,定义两个类。
复制代码 代码如下:
//构造函数
function Person(name) {
this.name = name;
}
//原型对象
var proto = {
getName : function(){return this.name},
setName : function(name){this.name = name;}
}
//定义两个类
var Man = $define(Person,proto);
var Woman = $define(Person,proto);
console.log(Man == Woman);//false,同一个构造函数(Person)定义不同的类
推荐阅读
-
javascript 写类方式之五_js面向对象
-
JavaScript 面向对象的之私有成员和公开成员_js面向对象
-
javascript 模式设计之工厂模式学习心得_js面向对象
-
Javascript基础回顾之(三) js面向对象
-
前端笔记之JavaScript面向对象(三)初识ES6&underscore.js&EChart.js&设计模式&贪吃蛇开发
-
重学js之JavaScript 面向对象的程序设计(创建对象)
-
Javascript基础回顾之(三) js面向对象
-
javascript Base类 包含基本的方法_js面向对象
-
javascript类式继承新的尝试_js面向对象
-
JavaScript 面向对象之命名空间_js面向对象