原型
person里面没有introduce(),那为什么还会在person多出这个方法呢?
其实introduce()是在__proto__
里面,这个是Chrome浏览器根据ES5标准,名字定义为[[Prototype]]
,两者意义相同,均表示对象的内部属性,其值指向对象原型,这个属性每个
对象都有。
我们将__proto__
称作隐式原型
,当我们在对象上找一个属性或者方法时,在当前对象找到不到,那么就会去__proto__
上查找,如果在隐式原型上找到属性或者方法时,就会访问调用。对于隐式原型,可以通过person.__proto__
来访问
刚才通过new 实例化出对象 person,在person.__proto__
可以访问其原型,然而我们通过Person.prototype
也可以访问其原型,我们称prototype
为显式原型,通过比较
可以发现显式原型和隐式原型都指向同一个对象。
原型链
在stu对象中没有eat(),所以要去其原型上去找,在原型上没有run(),则又去原型的原型上去找,这样行程一个链,称为原型链,其查找的顺序为:当前实例–>实例的原型–>原型的原型…,也可以理解成从父对象去找,父对象没有,再去父对象的父对象里找…直到null,即原型链.
prototype和__proto__联系
prototype
与__proto__
都指向原型对象,任意一个函数(包括构造函数)都有一个prototype属性,指向该函数的原型对象;- 任意一个构造函数实例化的对象,都有一个__proto__对象,它指向构造函数的原型对象.
prototype和__proto__区别
- prototype是函数独有的,而
__proto__
是每个对象都会拥有的(包括函数) - prototype的作用是保存所有实例公共的属性和方法;
__proto__
的作用是当访问一个对象的属性时,如果内部没有该属性,就会在它的__proto__
属性所指的那个父对象去找,父对象没有,再去父对象的父对象里找…直到null,即原型链. - prototype还有一个constractor属性,指向该对象的构造函数本身.