《悟透JavaScript》学习札记十一之原型真谛二
来源:互联网 发布:剑网3女神脸数据 编辑:程序博客网 时间:2024/05/01 18:28
承接上篇原型真谛一,下面是个更丰富的示例:
<script type="text/javascript">
var object = // 定义小写的object基本类,用于实现最基础的方法
{
isA: function(aType) // 用于判断类间及对象与类间关系的基础方法
{
var self = this;
while(self)
{
if(self == aType)
return true;
self = self.Type;
};
return false;
}
};
function Class(aBaseClass, aClassDefine) // 创建类的函数,用于声明类及继承关系
{
function class_() // 创建类的临时函数壳
{
this.Type = aBaseClass; // 我们给每一个类约定一个Type属性,引用其继承的类
for(var member in aClassDefine)
this[member] = aClassDefine[member]; // 复制类的全部定义到当前创建的类
};
class_.prototype = aBaseClass;
return new class_();
};
function New(aClass, aParams) // 创建对象的函数,用于任意类的对象创建
{
function new_() // 创建对象的临时函数壳
{
this.Type = aClass; // 给每一个对象约定一个Type属性,据此可以访问到对象所属的类
if(aClass.Create)
aClass.Create.apply(this, aParams); // 约定所有类的构造函数都叫Create
};
new_.prototype = aClass;
return new new_();
};
// 应用效果
var Person = Class(object, // 派生自object基本类
{
Create: function(name, age)
{
this.name = name;
this.age = age;
},
SayHello: function()
{
alert("Hello, I'm " + this.name + " , " + this.age + " years old!");
}
});
var Employee = Class(Person, // 派生自Person类
{
Create: function(name, age, salary)
{
Person.Create.call(this, name, age); // 调用基类的构造函数
this.salary = salary;
},
ShowSalary: function()
{
alert(this.name + " $ " + this.salary);
}
});
var Bill = New(Person, ["Bill", 30]);
var Steve = New(Employee, ["Steve", 28, 5000]);
Bill.SayHello();
Steve.SayHello();
Steve.ShowSalary();
var LittleBill = New(Bill.Type, ["LittleBill", 6]);
LittleBill.SayHello();
alert(Bill.isA(Person)); // true
alert(Bill.isA(Employee)); // false
alert(Steve.isA(Person)); // true
alert(Person.isA(Employee)); // false
alert(Employee.isA(Person)); // true
</script>
- 《悟透JavaScript》学习札记十一之原型真谛二
- 《悟透JavaScript》学习札记十一之原型真谛一
- 悟透JavaScript之原型真谛 --- (1)
- 悟透JavaScript之原型真谛---(2)
- 悟透JavaScript之原型真谛 ---(3)
- 悟透JavaScript-原型真谛
- 悟透JavaScript - 原型真谛
- 《悟透JavaScript》学习札记九之初看原型
- 《悟透JavaScript》学习札记十之原型扩展
- [转]悟透JavaScript 三.原型真谛
- 《悟透JavaScript》学习札记二之没有类
- 悟透JavaScript(李站老师)-原型真谛
- 《悟透JavaScript》学习札记之标准网页
- 再读《悟透javascript》之二、JavaScript原型
- javascript之对象学习笔记(二)--对象原型,继承
- 《悟透JavaScript》学习札记一之回归简单
- 《悟透JavaScript》学习札记三之函数的魔力
- 《悟透JavaScript》学习札记五之奇妙的对象
- LINUX 多线程编程
- delphi2010安装
- 利用HttpSessionListener统计在线人数
- Windows CE系统开发,BSP包中的几个常见文件详解
- 简单html学习总结
- 《悟透JavaScript》学习札记十一之原型真谛二
- js中关于document.domain的一些解释
- linux下系统命令输出到字符数组
- (2011.07.31)自学《C++ Primer Plus》时敲过的书上的代码!
- 诺基亚5530XM无法接收彩信(已解决)
- rails web 国际化
- 乱码问题处理汇总
- ICE的安装
- 麻省理工开放课程:计算机科学及编程导论