1、原型

一、prototype 在javascript中,每个函数都有一个prototype属性,这个属性指向函数的原型对象。 比如:

function Person(name){
	
}
Person.prototype.name = 'quxiaokang'
var person1 = new Person()
var person2 = new Person()
console.log(person1.name) //quxiaokang
console.log(person2.name)  //quxiaokang

函数的prototype指向了一个对象,而这个对象正是调用构造函数时创建的实例的原型,也就是person1和person2的原型。 也就是说函数的prototype和person1的__proto__是一样的

console.log(Person.prototype == person1.__proto__);//true

javascript原型与原型链_javascript

二、proto

每个对象除了Null外都有一个属性叫做__proto__,这个属性会指向该对象的原型。

function Person() {

}
var person = new Person();
console.log(person.__proto__ === Person.prototype); // true

javascript原型与原型链_构造函数_02

三、constructor

每个原型都有一个constructor属性,指向该关联的构造函数。

function Person() {
}
console.log(Person===Person.prototype.constructor)  //true

javascript原型与原型链_原型对象_03

面试如何回答?1、每一个函数都有一个prototype属性。 2、每一个实例都有一个__proto__属性 3、实例的__proto__属性指向函数的prototype

2、原型链

简单回顾一下构造函数、原型和实例对象之间的关系:每一个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。那么假如我们让原型对象等于另一个类型的实例,结果会怎样?显然,此时的原型对象将包含一个指向另一个原型的指针,相应地,另一个原型中也包含着一个指向另一个构造函数的指针。假如另一个原型又是另一个类型的实例,那么上述关系依然成立。如此层层递进,就构成了实例与原型的链条。这就是所谓的原型链的基本概念。——摘自《javascript高级程序设计》

javascript原型与原型链_原型对象_04

面试如何回答?

当我们访问一个函数的属性的时候,会先在本身中查找,如何没有找到就回去他的实例的__proto__中查找,即函数的prototype中查找,如何还没有找到的话就回去它的protopype的__proto__中查找,还是没有就去Obejct.prototype中查找,就这样一级一级往上,如果最后还是没有就返回undefined。