javascript中 每个对象都有个proto属性来访问到对象的原型对象
构造函数的prototype属性指向一个对象,这个对象是构造函数的实例对象的原型对象
原型对象的construcror也指向其构造函数
实例对象是通过原型对象上去访问找构造函数
function Person (name,age) {
this.name=name;//这个this指向的是新生成的对象
this.age=age;
}
var c =new Person('shu',18)
var b =new Person('wang',19)
创建一个函数时,函数里有个属性prototype,这个prototype指向一个对象 就是他的原型对象
对象有属性和方法,方法一般挂在到原型对象上
Person.prototype.showUserInfo=function(){
console.log(`${this.name},${this.age}`)
}
b.showUserInfo() //调用方法
c.showUserInfo()
我们新创建的对象可以通过__proto__查看原型对象 因为构造函数的prototype和实例对象的__proto__指向的都是原型对象 所以是相等的相同的
console.log(b.__proto__)
console.log(Person.prototype)
实例对象可以通过constructor来查看构造函数
b.constructor===person
总的来说 任何对像都有个属性prototype属性 这个属性指向对象的原型对象
在new一个实例对象以后 实例对象可以通过proto来访问到原型对象
原型对象上的constructor指向这个构造函数