网站首页 语言 会计 电脑 医学 资格证 职场 文艺体育 范文

理解JavaScript原型链教程

栏目: 网页设计 / 发布于: / 人气:2.58W

理解JavaScript原型链教程

理解JavaScript原型链教程

每一个JavaScript对象都和另一个对象相关联,相关联的这个对象就是我们所说的“原型”。每一个对象都会从原型继承属性和方法。有一个特殊的对象没有原型,就是Object。在之后的图示中会进行说明。

举个栗子,我们首先声明一个函数Student():

function Student(name){ = name; o = function(){ alert(`Hello,${}`); } }

这个函数包含一个属性name和一个方法hello。

在JavaScript中,可以通过new关键字来调用Student函数(不写new就是一个普通函数,写new就是一个构造函数),并且返回一个原型指向otype的对象,如下所示:

var xiaoming = new Student("xiaoming"); alert(); // xiaoming o(); // Hello,xiaoming

如果我们想确认一下我们的设想对不对,就会希望去比较一下otype和otype是否相等。

但是xiaoming没有prototype属性,不过可以用__proto__来查看。接下来我们就用这些属性来查看xiaoming,Student,Object之间的'原型链:

adystatechange = function(){ // interactive表示文档已被解析,但浏览器还在加载其中链接的资源 if(yState === "interactive"){ var xiaoming = new Student("xiaoming"); alert(); o(); ("xiaoming.__proto__:"); (xiaoming.__proto__); ("otype:"); (otype); ("xiaoming.__proto__ === otype:" + xiaoming.__proto__ === otype); ("tructor:" + tructor); ("otype:" + otype); ("otype.__proto__:"); (otype.__proto__); (otype); ("otype.__proto__ === otype:" + otype.__proto__ === otype); }}

七个红色箭头指向的就是七个语句的输出结果。用图例展示一下如图所示:

测试表明otype和otype.__proto__指向的Object并不是同一个。这个Object就是之前说的没有原型的那个Object,我们可以看到它并没有对应的prototype或者__proto__属性:

由图可得原型链如下所示:

由于本人语言表达能力有限,理解也比较浅显,所以图示比较多,错误之处还望指出,谢谢。

Tags:JavaScript