1、Object.getPrototypeOf(person1)==Person.prototype //true
Object.getPrototypeOf(person1).name //Person.prototype.name
(其中,person1是Person的一个实例)
原型中所保存的属性和方法是多个对象实例共享的。
Person.prototype 和 person1的prototype属性都指向Person.prototype;Person.prototype的constructor属性,指向Person,constructor属性也是Person的实例们共享的,所以person1.constructor是Person。
2、原型链:当代码要读取一个属性的时候,会执行一个搜索。先从对象实力本身开始,如果没有找到,接下来找指针指向的原型对象。(person1——》Person.prototype)
在实例上添加属性会屏蔽原型上的属性,可以用delete方法删除实例属性,就又可以访问到原型中的属性了。hasOwnProperty()方法可以检测属性是否存在于实例中。
注:读取属性时,可以用Object.getOwnPropertyDescriptor()方法来读取实例中的属性,如果想去的原型属性的描述符,必须直接在原型对象上调用。
3、原型与in操作符:
单独使用in时:alert('name' in person1) //返回布尔值,如果person1.name可以访问到(不论是在实例中还是在原型中)。可以配合person1.hasOwnProperty('name')来确定该属性是存在对象中还是存在原型中;
for-in循环时:循环到的是能够通过对象访问的、可枚举的属性,包括实例中的,也包括原型中的,比如一个属性在原型中是不可枚举的,但是在实例中又重新定义了,这个实例属性也会被枚举(但是这一点在ie8中就不会被枚举)。
要取得对象上所有可枚举的实例属性,可以用Object.keys(person1)方法,返回一个数组,包括了传入对象自己这一层的所有可枚举的属性。
Object.getOwnPropertyNames()方法可以得到所有实例属性,无论是否可枚举。
4、其实,用到原型的时候可以直接用一个对象赋值给Person.prototype,但是此时Person.prototype中的constructor不再指向Person,所以实例person1.constructor也不再是Person而是Object。虽然prototype找不到了,但是instanceof还可以找到从哪来的。不过也可以在Person.prototype赋值的时候加一条constructor:Person,这样就还可以找到了,但是这种情况下的constructor就是可枚举的,原生的constructor是不可枚举的,如果再想跟默认的一模一样的,可以再用Object.defineProperty()方法把constructor的enumerable设置为false。
5、当一个构造函数新建一个实例之后,再改变prototype里的属性,实例都可以继承,因为是指针指向的;但是如果此时重写prototype(把一个对象赋值给prototype) 实例还是会指向之前的prototype(不离不弃)