背景
最近看到了很有意思的东西,原型和原型链
我们首先看看MDN怎么讲:继承与原型链 - JavaScript | MDN
不过文档里面也没有给出原型的定义???
不过里面提到原型链,是指对象层层向上寻找原型形成的路径就叫做原型链
后面我参考了一些文章,在这里做一下总结:
参考(超赞):前端面试必考------原型及原型链(涵实例+话术)
我自己的定义:
原型: 每个函数创建好之后,都会添加一个prototype属性,这个就是原型!!!主要用来给实例提供公共属性和方法的。
每个函数都有一个prototype属性,指向其原型
每个引用类型都有一个__proto__属性,指向其构造函数的prototype属性
**原型链:**就是在代码执行过程中寻找变量,一层一层向上层原型遍历寻找匹配对象形成的这样一条链条
一些结论:
1.对于一个引用类型 (对象,数组,函数),我们通常会使用**proto** 或者**[[prototype]]** 来表示其原型,为了统一标准,官方推荐使用[[prototype]]来表示其原型,并使用专属的方法来修改原型
2.一个构造函数实例化的对象去寻找变量,先从第一层属性开始找,找不到再从原型上去匹配属性,还找不到再网上找原型,直到找到原型为Object.prototype(在往上就是null)
3.原型主要用来定义公共的属性和方法,利用继承来使得代码简洁
4.原型含有一个constructor引用,指向其构造函数。所以你可以在浏览器中点击prototype之后点击constructor............,这样一直点下去,不过我很好奇,这样为什么不炸???
5.构造函数实例化之后再设置该构造函数的原型 ,只会对实例的原型生效,而不会对该实例本身生效
6.如果父类属性和子类属性有对应的引用属性 ,那么子类实例对引用属性的修改 ,会影响到父类实例的对应属性(这个我还没试过)
其他参考: