javascript原型对象与原型链
来源:互联网 发布:中国现代汉语词典软件 编辑:程序博客网 时间:2024/05/21 08:42
javascript原型对象与原型链
原型对象
每个javascript对象都有一个原型对象,这个对象在不同的解释器下的实现不同。比如在firefox下,每个对象都有一个隐藏的__proto__属性,这个属性就是“原型对象”的引用。
原型链
由于原型对象本身也是对象,根据上边的定义,它也有自己的原型,而它自己的原型对象又可以有自己的原型,这样就组成了一条链,这个就是原型链,JavaScritp引擎在访问对象的属性时,如果在对象本身中没有找到,则会去原型链中查找,如果找到,直接返回值,如果整个链都遍历且没有找到属性,则返回undefined.原型链一般实现为一个链表,这样就可以按照一定的顺序来查找。
示例1
var base = { name : "base", getInfo : function(){ return this.name; } } var ext1 = { id : 0, __proto__ : base } var ext2 = { id : 9, __proto__ : base } print(ext1.id); print(ext1.getInfo()); print(ext2.id); print(ext2.getInfo());
结果:
0
base
9
base
可以看到,当执行ext1.id时,引擎在ext1对象本身中就找到了id属性,因此返回其值0,当执行ext1.getInfo时,ext1对象中没有找到,因此在其原型对象base中查找,找到之后,执行这个函数,得到输出”base”。
我们将上例中的ext1对象稍加修改,为ext1对象加上name属性:
示例2
var base = { name : "base", getInfo : function(){ return this.name; } } var ext1 = { id : 0, name : "ext1", __proto__ : base } print(ext1.id); print(ext1.getInfo());
结果:
0
ext1
这个运行效果同样验证了原型链的运行机制:从对象本身出发,沿着__proto__查找,直到找到属性名称相同的值(没有找到,则返回undefined)。
我们对上例再做一点修改,来更好的演示原型链的工作方式:
示例3
var base = { name : "base", getInfo : function(){ return this.id + ":" + this.name; } } var ext1 = { id : 0, __proto__ : base } print(ext1.getInfo());
结果:
0:base
应该注意的是,getInfo函数中的this表示原始的对象,而并非原型对象。上例中的id属性来自于ext1对象,而name来自于base对象。这个特性的机制在10.3小节再做讨论。如果对象没有显式的声明自己的”__proto__”属性,这个值默认的设置为Object.prototype,而Object.prototype的”__proto__”属性的值为”null”,标志着原型链的终结。
构造器
我们在来讨论一下构造器,除了上边提到的直接操作对象的__proto__属性的指向以外,JavaScript还支持构造器形式的对象创建。构造器会自动的为新创建的对象设置原型对象,此时的原型对象通过构造器的prototype属性来引用。
我们以例子来说明,将Task函数作为构造器,然后创建两个实例task1, task2:
示例4
function Task(id){ this.id = id; } Task.prototype.status = "STOPPED"; Task.prototype.execute = function(args){ return "execute task_"+this.id+"["+this.status+"]:"+args; } var task1 = new Task(1); var task2 = new Task(2); task1.status = "ACTIVE"; task2.status = "STARTING"; print(task1.execute("task1")); print(task2.execute("task2"));
结果:
execute task_1[ACTIVE]:task1
executetask_2[STARTING]:task2
构造器会自动为task1,task2两个对象设置原型对象Task.prototype,这个对象被Task(在此最为构造器)的prototype属性引用,参看下图中的箭头指向。
由于Task本身仍旧是函数,因此其”__proto__”属性为Function.prototype,而内建的函数原型对象的”__proto__”属性则为Object.prototype对象。最后Obejct.prototype的”__proto__”值为null
转载地址:http://www.cnblogs.com/xqhppt/archive/2012/02/01/2334355.html
- javascript原型对象与原型链
- javaScript 原型对象与原型链
- JavaScript原型对象、原型属性、原型链
- JavaScript原型与对象
- javascript原型与原型链
- JavaScript原型与原型链
- javascript原型与原型链
- 原型对象与原型链
- 原型对象与原型链
- 原型对象与原型链
- 原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- 三张图搞懂JavaScript的原型对象与原型链
- JavaScript面向对象技术·原型与原型链
- 电脑键盘工作原理
- Jetson TX1 开发教程(1)——配置与刷机
- Java中Servlet中cookie类源码
- java中的Set、List、Map的区别与用法
- Unrecognized Windows Sockets error: 0: JVM_Bind异常
- javascript原型对象与原型链
- leetoce(43).169. Majority Element
- 插值查找
- [分享] 揭开美国顶尖生物医学实验室成功的法宝--转
- websphere发布的工程迁移到tomcat容器下(绿色方式)
- js中typeof用法详细介绍
- [李景山php]每天TP5-20161229|thinkphp5-Controller.php
- 随心记
- 润乾报表实现当前数据行变色