JavaScript面向对象程序设计三原型模式(上)
JavaScript模式 面向对象 程序设计 原型
2023-06-13 09:14:32 时间
我们创建的每一个函数都有一个prototype(原型)属性,该属性是一个对象,包含可以有特定类型的所有实例共享的属性和方法。使用它的好处就在于可以让所有对象实例共享它所包含的属性和方法,也就是说,不必在构造函数中定义对象的信息,而是可以将这些信息,直接添加在原型对象中,如下所示,还是接着改写前两篇日志中的例子:
复制代码代码如下:
functionEmployee(){
};
Employee.prototype.Name="Jim";
Employee.prototype.Age=28;
Employee.prototype.Job="SoftWareEngineer";
Employee.prototype.SayName=function(){
alert(this.Name);
};
varemployee1=newEmployee();
employee1.SayName();//Jim
varemplayee2=newEmployee();
emplayee2.SayName();//Jim
alert(employee1.SayName=emplayee2.SayName);//true
与构造函数模式不同的是,新对象的这些属性和方法是由所有实例共享的。
以上即是原型模式的一个引子,要理解原型模式的工作原理,就需要了解ECMASCRIPT中原型的性质。
理解原型
在Javascript中,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性。在默认的情况下,虽有prototype属性都会自动获得一个constructor属性,这个属性包含一个指向prototype属性所在函数的指针,而通过这个构造函数,我们还可以继续为原型添加其他属性和方法。
创建了自定义的构造函数之后,其原型属性默认只会取得constructor属性,而至于其他的方法,则都是从Object继承来的。当调用构造函数创建一个新实例后,该实例的内部将包含一个指针(内部属性),指向构造函数的原型属性。要注意的是这个连接存在于实例和构造函数原型属性之间,而不是存在于实例与构造函数之间。
在某些实现中,无法访问到内部属性(_proto_属性),但是在所有实现中都可以通过isPrototypeOf方法来确定对象之间是否存在这种原型关系。从本质上来看,如果对象的_proto_属性指向isPrototypeOf,这个方法就返回true。如下所示:
alert(Employee.prototype.isPrototypeOf(employee1));//true
alert(Employee.prototype.isPrototypeOf(employee2));//true
每当代码读取某个对象的某个属性时,都会执行搜索,目标是具有给定名字的属性。搜索最先从对象实例本身开始。如果在实例中找到具有给定名字的属性,则然后该属性的值,如果没有找到,则继续搜索指针指向的原型对象,在原型对象中查找具有给定名字的属性。如果在原型对象中找到这个属性,则返回该属性的值。这也正是对个对象实例共享原型所保存的属性和方法的基本原理。
前面说过,原型最初只包含constructor属性,而该属性也是共享的,因此可以通过对象实例访问
虽然可以通过对象实例访问保存在原型中的值,但是不能通过对象实例重写原型中的值,如果我们在实例中添加一个属性,而该属性与实例原型中的一个属性名称相同,name在实例中创建的属性会屏蔽(.net成为隐藏)原型中的那个属性,如下所示:
functionEmployee(){
};
Employee.prototype.Name="Jim";
Employee.prototype.Age=28;
Employee.prototype.Job="SoftWareEngineer";
Employee.prototype.SayName=function(){
alert(this.Name);
};
emplayee2.Name="Sun";
alert(employee1.Name);//Jim
alert(employee2.Name);//Sun
其中employee1.Name的Jim来自原型,二employee2.Name的sun来自实例。
相关文章
- JavaScript 设计模式 —— 代理模式
- 「设计模式 JavaScript 描述」代理模式
- javascript中的Number类型转换详解编程语言
- Javascript实现的分页函数
- Javascript注入技巧
- Javascript更新JavaScript数组的uniq方法
- Javascript阻止javascript事件冒泡,获取控件ID值
- JavaScript异步调用框架(Part6-实例&模式)
- javascript中最常用的继承模式组合继承
- functional继承模式摘自javascript:thegoodparts
- javascript全选与全取消功能的实现代码
- 谈谈关于JavaScript中的MVC模式
- 理解Javascript闭包
- JavaScript判断访问的来源是手机还是电脑,用的哪种浏览器
- Javascript自定义函数判断网站访问类型是PC还是移动终端
- JavaScript简单实现鼠标拖动选择功能
- JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
- javascript版的in_array函数(判断数组中是否存在特定值)
- javascript设计模式之解释器模式详解
- JavaScript异步回调的Promise模式封装实例
- JavaScript中发布/订阅模式的简单实例
- JavaScript设计模式之抽象工厂模式介绍
- javascript中键盘事件用法实例分析