1.构造继承
使用构造函数来继承
function Star(name,age){
this.name=name
this.age=age
this.sayName=function(){
console.log(this.name)
}
}
Star.prototype.sing=function(){
alert(this.name)
}
var ldh=new Star('刘德华',28)
var zxy=new Star('张学友',29)
构造函数的缺陷:
里边有方法的话,就会新开一个空间,每次 new 一个对象都会开辟一个
所以 prototype 就是解决方法
在这里使用了new之后他执行了下边4步
* 1.创建一个新的空对象
* 2.让this指向这个对象
* 3.执行构造函数里的代码,添加属性和方法
* 4.返回这个对象
实例成员就是构造函数内部通过this添加的成员
如上的name age sayName都是实例成员
实例成员只能通过实例化对象来访问,不能用构造函数来使用
ldh.name //刘德华
Star.name //undefined
Star.sex是静态成员(即,给构造函数添加属性,只能通过构造函数来访问)
Star.sex='nan'
console.log(Star.sex,ldh.sex) //nan,undefined
__proto__存在的意义,就是让对象访问到构造函数的原型,在实际开发中,不可以使用这个属性