一、prototype
我们先看一段代码:这段代码里,obj
对象里并没有toString
函数,但是并没有报错,那么这个函数是从何而来呢?
let obj = {}
obj.toString()
在js中,window
是一个对象,为方便理解,我们先console.log(window)
,如下图:
window 中有个 object
属性,object
中有个 prototype
,prototype
中又有 toString
、 valueOf
等属性。
看到这你应该就理解这个这段代码是如何“无中生有”了吧,不理解也没关系,再上代码验证:
let obj = {}
obj.toString === window.Object.prototype.toString? alert("true") : alert("flase");
//true
没错,这段代码的输出是true
,prototype
是不是就好理解了呢?prototype
指向了存放共用属性的内存
二、总结:
1、prototype
指向存放共用属性的内存;
2、__proto__
指向同一块内存;
3、prototype
属性是函数所独有的;__proto__
和 constructor
属性是对象所独有的,函数也是一种对象;
3、constructor
属性的含义就是指向该对象的构造函数
4、__proto__
属性的作用就是当访问一个对象的属性时,如果该对象内不存在这个属性,那么就会去它的__proto__
属性所指向的那个对象里找,直到__proto__
属性的终点null,null为原型链的终点,再往上找会报错。通过__proto__
属性来连接对象直到 null 的这条链即原型链
。