js 原型继承

1、借助Object.create方法实现普通对象的继承(浅拷贝)

let parent4 = {
  name: "parent4",
  friends: ["p1", "p2", "p3"],
  getName: function() {
    return this.name;
  }
};


let person4 = Object.create(parent4);
person4.name = "tom";
person4.friends.push("jerry");

let person5 = Object.create(parent4)
person5.name = 'james'
person5.friends.push('james')

console.log(parent4)

2、寄生组合式继承

function clone(p, c) {
  c.prototype = Object.create(p.prototype)
  c.prototype.constructor = c
}
function Parent6() {
  this.name = 'parent6'
  this.play = [1,2,3]
}

Parent6.prototype.getName = function()  {
  return this.name
}

function Child6() {
  Parent6.call(this)
  this.friends = 'child6';
} 

clone(Parent6, Child6)
Child6.prototype.getF = function () {
  return this.friends
}
let c6 = new Child6()
console.log(c6)
console.log(c6.getName()); // parent6
console.log(c6.getF()); // child5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值