理解JavaScript原型链教程
本文共计1908个字,预计阅读时长7分钟。【 字体:大 中 小 】
理解JavaScript原型链教程
理解JavaScript原型链教程
每一个JavaScript对象都和另一个对象相关联,相关联的这个对象就是我们所说的“原型”。每一个对象都会从原型继承属性和方法。有一个特殊的对象没有原型,就是Object。在之后的图示中会进行说明。
举个栗子,我们首先声明一个函数Student():
function Student(name){ this.name = name; this.hello = function(){ alert(`Hello,${this.name}`); } }
这个函数包含一个属性name和一个方法hello。
在JavaScript中,可以通过new关键字来调用Student函数(不写new就是一个普通函数,写new就是一个构造函数),并且返回一个原型指向Student.prototype的对象,如下所示:
var xiaoming = new Student("xiaoming"); alert(xiaoming.name); // xiaoming xiaoming.hello(); // Hello,xiaoming
如果我们想确认一下我们的设想对不对,就会希望去比较一下xiaoming.prototype和Student.prototype是否相等。
但是xiaoming没有prototype属性,不过可以用__proto__来查看。接下来我们就用这些属性来查看xiaoming,Student,Object之间的原型链:
document.onreadystatechange = function(){ // interactive表示文档已被解析,但浏览器还在加载其中链接的资源 if(document.readyState === "interactive"){ var xiaoming = new Student("xiaoming"); alert(xiaoming.name); xiaoming.hello(); console.log("xiaoming.__proto__:"); console.log(xiaoming.__proto__); console.log("Student.prototype:"); console.log(Student.prototype); console.log("xiaoming.__proto__ === Student.prototype:" + xiaoming.__proto__ === Student.prototype); console.log("Student.prototype.constructor:" + Student.prototype.constructor); console.log("Student.prototype.prototype:" + Student.prototype.prototype); console.log("Student.prototype.__proto__:"); console.log(Student.prototype.__proto__); console.log(Object.prototype); console.log("Student.prototype.__proto__ === Object.prototype:" + Student.prototype.__proto__ === Object.prototype); }}
七个红色箭头指向的就是七个console.log语句的输出结果。用图例展示一下如图所示:
测试表明Object.prototype和Student.prototype.__proto__指向的Object并不是同一个。这个Object就是之前说的没有原型的那个Object,我们可以看到它并没有对应的prototype或者__proto__属性:
由图可得原型链如下所示:
由于本人语言表达能力有限,理解也比较浅显,所以图示比较多,错误之处还望指出,谢谢。


经济管理创新研究论文
化学分析仪器在环保水质检测方面的应用
分析化学在陶瓷原材料检测方面的应用及举例
秦腔的来源和发展
HACMP的历史和发展
象棋的变化和发展
试析我国内衣的发展趋势毕业论文
EDA技术的发展与应用
IP在EDA技术的应用和发展中的意义
探究计算机技术的发展和应用论文
EDA的应用和发展趋势
电子采购的应用和发展
工程施工中材料价格风险的控制与管理论文
浅谈塑木材料在园林景观工程中的应用的论文
相变材料对轻质建筑室内热环境的改善论文
材料语言在室内空间设计中的应用论文
水利水电工程混凝土材料成本优化研究论文
浅析影视动画在教育教学中有效应用研究论文
高分子材料简历模板
生活中的高分子材料