1.构造函数中的成员
构造函数有静态成员和实例成员
<script>
function Star(name,age) {
this.uname = name;
this.age = age;
this.song = function() {
}
}
Star.sex = '男',
let ldh = new Star('刘德华','18');
console.log(ldh.age);
console.log(Star.sex);
</script>
构造函数通过new关键字创建一个实例对象
在以上实例中,构造函数Star()用this创建的属性和方法都是实例成员,只能通过实例对象来调用
在构造函数内部创建的成员,如上例中的Star.sex = '男', 这种成员为静态成员,只能通过构造函数来调用
2.原型
构造函数也是一个函数,每一个函数都会创建一个prototype属性,prototype是一个对象,包含有特定引用类型的实例所包含的属性和方法。所以,prototype对象就是通过构造函数创建的对象的原型,在它上面的属性和方法都能被实例对象共享
只要创建一个函数,就会创建一个prototype属性,指向函数的原型对象,而所有对象都会获得constructor 属性,指回构造函数
3,原型链
只要创建一个函数,就会创建一个prototype属性,指向函数的原型对象,而所有对象都会获得constructor 属性,指回构造函数
当通过构造函数创建一个实例对象,只要是对象,都会暴露一个__proto__属性,通过这个属性可以访问 原型对象prototype,所以实例对象可以访问原型对象里的属性和方法,然后,因构造函数而异,可以给原型对象添加其他的属性和方法
当实例对象没有在原型对象找到属性和方法时,原型对象会通过自身的__proto__属性访问Object的原型对象(Obejct.prototype),此原型对象的constructor属性会指向Obejct构造函数,如果还是没有,则返回null。
所以,在这种查找规则下,这种查找方式就形成原型链
理解这一过程关键在于:实例与构造函数原型之间有直接关系,实例与构造函数之间没有