JavaScript继承,原型式继承

/**
 * 原型式继承:基于原型,基于已有的对象创建新对象
 * 优点:如果只想让一个对象与另一个对象保持类似的情况下,原型式继承是完全可以胜任的,不需要大兴地创建构造函数
 * 缺点:引用类型的属性值始终共享
 * object()对传入对象o执行了一次浅复制
 * Object.creat();
 */


function object(o){
    function F(){}         //创建临时构造函数
    F.prototype = o;       //将传入对象作为构造函数的原型
    return new F();              //返回类型的新实例
}

var person = {
        name: "Nicholas",
        friends:["Shelby","Court","Van"]
};

var person1 = object(person);

person1.name = "Greg";
person1.friends.push("Rob");

var person2 = object(person);
person2.name = "Linda";
person2.friends.push("Barbie");

console.log(person.friends);

var person3 = Object.create(person);
person3.name = "Susie";
person3.friends.push("Rob");
console.log(person.friends);

var person4 = Object.create(person,{name:{value:"Greg"}}
    );
console.log(person4.name);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值