我们创建的每一个函数都有一个prototype(原型)属性,该属性是一个对象,包含可以有特定类型的所有实例共享的属性和方法。使用它的好处就在于可以让所有对象实例共享它所包含的属性和方法,也就是说,不必在构造函数中定义对象的信息,而是可以将这些信息,直接添加在原型对象中,如下所示,还是接着改写前两篇日志中的例子: 与构造函数模式不同的是,新对象的这些属性和方法是由所有实例共享的。 以上即是原型模式的一个引子,要理解原型模式的工作原理,就需要了解ECMASCRIPT中原型的性质。 理解原型 在Javascript中,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性。在默认的情况下,虽有prototype属性都会自动获得一个constructor属性,这个属性包含一个指向prototype属性所在函数的指针,而通过这个构造函数,我们还可以继续为原型添加其他属性和方法。 创建了自定义的构造函数之后,其原型属性默认只会取得constructor属性,而至于其他的方法,则都是从Object继承来的。当调用构造函数创建一个新实例后,该实例的内部将包含一个指针(内部属性),指向构造函数的原型属性。要注意的是这个连接存在于实例和构造函数原型属性之间,而不是存在于实例与构造函数之间。 在某些实现中,无法访问到内部属性(_proto_属性),但是在所有实现中都可以通过isPrototypeOf方法来确定对象之间是否存在这种原型关系。从本质上来看,如果对象的_proto_属性指向isPrototypeOf,这个方法就返回true。如下所示: 每当代码读取某个对象的某个属性时,都会执行搜索,目标是具有给定名字的属性。搜索最先从对象实例本身开始。如果在实例中找到具有给定名字的属性,则然后该属性的值,如果没有找到,则继续搜索指针指向的原型对象,在原型对象中查找具有给定名字的属性。如果在原型对象中找到这个属性,则返回该属性的值。这也正是对个对象实例共享原型所保存的属性和方法的基本原理。 前面说过,原型最初只包含constructor属性,而该属性也是共享的,因此可以通过对象实例访问 虽然可以通过对象实例访问保存在原型中的值,但是不能通过对象实例重写原型中的值,如果我们在实例中添加一个属性,而该属性与实例原型中的一个属性名称相同,name在实例中创建的属性会屏蔽(.net成为隐藏)原型中的那个属性,如下所示: 其中employee1.Name的Jim来自原型,二employee2.Name的sun来自实例。
推荐整理分享JavaScript面向对象程序设计三 原型模式(上)(javascript面向对象编程),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:javascript面向对象编程指南,javascript面向对象编程指南 pdf,javascript面向对象精要pdf下载,javascript面向对象编程指南第三版,javascript面向对象编程,javascript面向对象精要pdf,javascript面向对象吗,javascript面向对象编程指南,内容如对您有帮助,希望把文章链接给更多的朋友!
JavaScript 原型继承 Object.prototypeJavaScript是基于原型继承的,任何对象都有一个prototype属性。Object.prototype是所有对象的根,并且不可改变。Object.prototype=null;alert(Object.prototype
js 函数调用模式小结 方法调用模式当一个函数被保存为对象的一个属性时,我们称之它为该对象的一个方法,那么this被绑定到该对象上。varmyObject={name:"myObject",value:0,increment
javascript类式继承新的尝试 我今天做的尝试是,如何更它更像其他的语言一样的使用继承机制,多层继承和更方面的调用父类的构造。我希望达到的效果:functionA(){alert('a');}function