关于JavaScript的继承

// es6 的继承 extends
class People {
 constructor(name = "liang", age = "27") {
   this.name = name;
   this.age = age
 }
 eat() {
   console.log(`${this.name} ${this.age} eat food`);
 }
}
// es6 继承
class Woman extends People {

 constructor(name = 'wang', age = " 30") {
   super(name, age)
 }
 eat() {
   super.eat()
 }
}

let wm = new Woman()
wm.eat()
// es5 的寄生式组合继承
function Animal(obj) {
  this.name = obj.name;
  this.age = obj.age;
}
Animal.prototype.add = function (value) {
  console.log(value)
}

var dog = new Animal({ name: 'doggo', age: 6 })
dog.add('hahaha')

console.log(Animal.prototype === dog.__proto__); // true
console.log(Animal.prototype.constructor === Animal); // true

function Cat(obj) {
  Animal.call(this, obj) // super(obj)
  this.sex = obj.sex
}

// 这句是关键
Cat.prototype = Object.create(Animal.prototype); 
Cat.prototype.constructor = Cat;

var cat = new Cat({ name: 'miaomiao', age: 4, sex: 'boy' })
console.log(cat);
cat.add('miaomiaomiao')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值