浅尝原型链
ECMAScript中的对象是一个无序属性的集合,其属性可以包含基本值、对象或者函数,它拥有一个prototype对象。
一个对象的prototype是以内部的[[Prototype]]属性来引用的。对于prototype对象来说,我们使用__proto__(firefox,chrome)来表示。
原型对象也是简单的对象并且可以拥有它们自己的原型。如果一个对象的原型是一个非null的引用,那么以此类推,这就是原型链。
原型链窥视
我们来看一个例子,看一个普通对象的整个原型链的结构。
var mike = { sex:"male", location:"beijing" } console.log(mike);
下图是在chrome浏览器里的变量原型链结构:
原型链结构图:
分析:
根据上图,我们可以看到定义的mike对象有两个自身属性sex和location,mike这个对象有个[[Prototype]]属性__proto__,指向了【Object的prototype对象】,该对象没有了内置的[[Prototype]]属性,它自带一个constructor属性,该属性指向【Object构造函数】,在【Object构造函数】中有prototype属性,该属性指回了【Object的prototype对象】,【Object构造函数】中有个__proto__属性指向了【Function的prototype对象】,该对象的constructor指向了【Function构造函数】,而其内的__proto__对象指向了【Object的prototype对象】,在【Function构造函数】中的prototype对象指回了【Function的prototype对象】,__proto__对象指向了【Object的prototype对象】。
以上例子我们可以看到一个普通对象的整个原型链情况,那么原型链到底干嘛用的呢?
原型链用处
原型链是一个指针,指向一个对象,它的用途是包含可以由特定类型的所有实例共享的属性和方法。它的好处就是让所有对象实例共享它包含的属性和方法。
共享属性和方法
function Person(){ } Person.prototype.name='mike'; Person.prototype.location='beijing'; Person.prototype.sayHello=function(){ console.log('Hello'); }; var mike = new Person(); console.log(mike); var zeromike=new Person(); console.log(zeromike);
我们可以看到在mike和zeromike两个对象中具有相同的属性和方法,这也是原型链最基本的用法。
继承
在ECMAScript中实现继承主要是依靠原型链来实现的。
我们回顾一下构造函数,原型和实例的关系:每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。如果让原型对象等于另一个类型的实例,此时的原型对象将包含一个指向另一个原型的指针。相应地,另一个原型中也包含着一个指向另一个构造函数的指针。如果另一个原型又是另一个类型的实例,那么上述关系依然成立,如此层层递进,就构成了实例与原型的链条。这是原型链的基本概念。我们就依靠这个概念来实现继承。
function SuperType(){ this.property=true; } SuperType.prototype.getSuperValue = function(){ return this.property; } function SubType(){ this.subproperty=false; } SubType.prototype=new SuperType(); SubType.prototype.getSubValue=function(){ return this.subproperty; } var instance = new SubType(); console.log(instance.subproperty);
以上代码定义了两个类型:SuperType和SubType。每个类型分别有一个属性和一个方法。它们的主要区别是SubType继承了SuperType。而继承是通过创建SuperType的实例,并将该实例赋给SubType.prototype实现的。实现的本质是重写原型对象,代之以一个新类型的实例。换句话说,原来存在于SuperType的实例中的所有属性和方法,现在也存在于SubType.prototype中了。在确立了继承关系后,给SubType.prototype添加一个方法,这样就在继承了SuperType的属性和方法的基础上又添加了一个新方法。这个例子中的实例及构造函数和原型之间的关系如图:
在上面的代码中,我们没有使用SubType默认提供的原型,而是给它换了新原型:这个新原型就是SuperType的实例。于是,新原型不仅具有作为一个SuperType的实例所拥有的全部属性和方法,而且其内部还有一个指针,指向了SuperType的原型。getSuperValue()方法仍然还在SuperType.prototype中,但property则位于SubType.prototype中。这是因为property是一个实例属性,而getSuperValue()则是一个原型方法。既然SubType.prototype现在是SuperType的实例,那么property当然就位于该实例中了。此外,要注意instance.constructor现在指向的是SuperType,这是因为原来SubType.prototype中的constructor被重写了的缘故。实际上,不是SubType的原型的constructor属性被重写了,而是SubType的原型指向了另一个对象SuperType的原型,而这个原型对象的constructor属性指向的是SuperType.
ITEYE的编辑器是我见过的最差的编辑器了。。。。
相关推荐
本文将从UEFI BIOS浅说 pptx文件中提炼出重要的知识点,以下是详细的解释: 一、BIOS 的概念和功能 BIOS(Basic Input/Output System,基本输入输出系统)是电脑中的一组固化程序,提供最低级的硬件控制。它是连接...
- **光速不变原理**:无论光源和观察者如何运动,在任何惯性参考系中测量到的真空中的光速都是恒定的。 - **相对性原理**:物理定律的形式在所有惯性参考系中都是相同的。 #### 1.3 主要结论 - **时间膨胀**:当...
系统论、信息论、控制论是现代科学技术中的三个重要理论,它们诞生于20世纪中叶,是现代科学方法论的重要组成部分。本书旨在向读者普及这三个理论的基本知识,特别适合具有一定文化程度的普通读者。下面详细阐述这三...
爱因斯坦通过引入“光速不变原理”,即光在真空中的速度对于所有惯性观察者而言都是恒定的,无论光源和观察者是否处于相对运动状态,从而解决了经典物理学中的矛盾。 “几何命题的物理意义”这一概念强调了空间和...
在探讨语文教学中的未知情感时,我们首先需要明确“未知情感”的定义及其在文学作品中的重要性。未知情感通常指的是在鉴赏文学作品时,由于审美角度的不同,每个人都能得出不同的结论和感受,这些结论和感受虽然存在...
### 浅说政治课堂教学中的“开场白”艺术 #### 教材说明与目的 本教材旨在探讨并提升政治课堂教学中的“开场白”艺术,适用于小学阶段的政治科目教学。其核心目的是通过有效的开场白技巧,帮助学生更好地理解社会...
浅说顾客满意度.ppt
海典H1自定义事件框架浅说 1、窗口概述 2 2、窗口相关事件 3 1、打开窗口 3 key事件 4 timer事件 4 2、保存数据 4 1、 pfc_begintran 4 3、 pfc_endtran 4 4、 Pfc_save 4 3、关闭窗口 4 3、数据窗口事件 5 添加主...
浅说元代的监察制度.pdf
浅说信息时代的媒体.pdf
科技论文写作浅说。本人写的PPT文档。根据张孙伟老师的书,编写。为何把“科技论文写作”作为一门独立的课程? 要准确地把科技成果记录下来,应该规范地按照科技论文的要求进行。 科技论文的写作,在形式上有一...
很抱歉,但根据您提供的信息,标题和描述中的"深化浅说长路慢走[路要慢走的散文].rar"以及压缩包内的文件"深化浅说长路慢走[路要慢走的散文].pdf"似乎与IT行业知识并无直接关联。它们更可能属于文学或哲学类的内容,...
我国高压电网浅说设计说明.doc
初中语文语文论文语感素质培养浅说
博弈论与信息经济学浅说.docx
博弈论与信息经济学浅说.doc
小学语文教学中的朗读是培养学生语文素养的重要手段。朗读不仅是文字的呈现,更是情感的传达和理解的深化。在教学过程中,通过朗读,学生能够更好地感知文章的韵律和意境,体会作者的情感,进而培养语感和审美能力。...