欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JavaScript继承,原型式继承

程序员文章站 2022-06-15 14:55:06
...
/**
 * 原型式继承:基于原型,基于已有的对象创建新对象
 * 优点:如果只想让一个对象与另一个对象保持类似的情况下,原型式继承是完全可以胜任的,不需要大兴地创建构造函数
 * 缺点:引用类型的属性值始终共享
 * 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);