js原型链
来源:互联网 发布:windows7查看443端口 编辑:程序博客网 时间:2024/04/19 21:35
1、原型链<span><span></span></span>
1.1.1原型对象与原型链
javaScript对象是一个属性的集合,另外有一个隐式的对象:原型对象。原型的值可以是一个对象或者null。一般的引擎实现中,JS对象会包含若干个隐藏属性,对象的原型由这些隐藏属性之一引用,我们在本文中讨论时,将假定这个属性的名称为"__proto__"(事实上,SpiderMonkey内部正是使用了这个名称,但是规范中并未做要求,因此这个名称依赖于实现)。
由于原型对象本身也是对象,根据上边的定义,它也有自己的原型,而它自己的原型对象又可以有自己的原型,这样就组成了一条链,这个链就是原型链。
JavaScritp引擎在访问对象的属性时,如果在对象本身中没有找到,则会去原型链中查找,如果找到,直接返回值,如果整个链都遍历且没有找到属性,则返回undefined.原型链一般实现为一个链表,这样就可以按照一定的顺序来查找。
<span style="font-size:14px;">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());</span>结果:
<span style="font-size:14px;">0base9base</span>
可以看到,当执行ext1.id时,引擎在ext1对象本身中就找到了id属性,因此返回其值0,当执行ext1.getInfo时,ext1对象中没有找到,因此在其原型对象base中查找,找到之后,执行这个函数,得到输出”base”。
我们将上例中的ext1对象稍加修改,为ext1对象加上name属性:
<span style="font-size:14px;">var base = { name : "base", getInfo : function(){ return this.name; }} var ext1 = { id : 0, name : "ext1", __proto__ : base} print(ext1.id);print(ext1.getInfo());</span>结果:
0ext1
这个运行效果同样验证了原型链的运行机制:从对象本身出发,沿着__proto__查找,直到找到属性名称相同的值(没有找到,则返回undefined)。
我们对上例再做一点修改,来更好的演示原型链的工作方式
var base = { name : "base", getInfo : function(){ return this.id + ":" + this.name; }} var ext1 = { id : 0, __proto__ : base} print(ext1.getInfo());
我们在getInfo函数中加入this.id,这个id在base对象中没有定义。同时,删掉了ext1对象中的name属性,执行结果如下
0:base1.1.1构造器应该注意的是,getInfo函数中的this表示原始的对象,而并非原型对象。上例中的id属性来自于ext1对象,而name来自于base对象。如果对象没有显式的声明自己的”__proto__”属性,这个值默认的设置为Object.prototype,而Object.prototype的”__proto__”属性的值为”null”,标志着原型链的终结。
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]:task1execute task_2[STARTING]:task2
构造器会自动为task1,task2两个对象设置原型对象Task.prototype,这个对象被Task(在此最为构造器)的prototype属性引用。
由于Task本身仍旧是函数,因此其”__proto__”属性为Function.prototype, 而内建的函数原型对象的”__proto__”属性则为Object.prototype
对象。最后Obejct.prototype的”__proto__”值为null.
- JS原型、原型链
- JS-原型、原型链
- JS原型,原型链
- js原型,原型链
- JS原型+原型链
- JS原型和原型链
- JS原型和原型链
- JS原型和原型链
- JS原型和原型链
- js 原型和原型链
- JS 原型与原型链
- JS原型和原型链
- js原型与原型链
- JS原型与原型链
- JS:原型、原型链、继承
- js原型和原型链
- JS原型及原型链
- js---原型与原型链
- hdu 3033 I love sneakers!
- oracle性能优化(一)
- 单点登录
- 1、Cocos2dx 3.0游戏开发找小三之前言篇
- acm-继承与组合
- js原型链
- MFC实现为窗体添加的背景图片
- redis在windows下的安装
- 初步认识迭代服务器和并发服务器
- 强大的vim配置文件,让编程更随意
- 注意php in_array带来的低性能
- VC中使用GDI+实现为按钮加载Png图片
- return 0 与exit(0)
- java中List的遍历