Object.create()和new 创建对象的区别

Posted fsg6

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Object.create()和new 创建对象的区别相关的知识,希望对你有一定的参考价值。

Object.create()方法是ECMAScript5中新增的,用来规范化原型式继承的。
这个方法接收两个参数,一个是用作新对象原型的对象,和一个为新对象定义额外属性的(可选)对象。

  var person = {
      name: "Nicholas",
      friends: ["John", "Jane"] // 引用类型值属性共享
    }

    var onePerson = Object.create(person); // onePerson继承person对象
    
    console.log(onePerson)  //{},自己空对象,可以通过隐士原型继承person
    console.log(onePerson.name,onePerson.friends )  //Nicholas , ["John", "Jane"]

    onePerson.name = "Greg";
    onePerson.friends.push("Mike"); 
    console.log(onePerson.name); //onePerson自己添加的name属性  Greg
    console.log(onePerson.friends); //修改person原型对象的friends ["John", "Jane", "Mike"]
    console.log(onePerson); //{name: "Greg"}
 
// 第二个参数对象格式与Object.defineProperties()方法的第二个参数格式相同
var theOtherPerson = Object.create(person, {
              name : {
                configurable : false,  // 不可修改
                value : "Greg"
              }
});
console.log(theOtherPerson.name);  // Greg
theOtherPerson.name = "Bob";  // 失效
console.log(theOtherPerson.name);  // Greg


new Object()方法的实质是,使用引用类型Object的构造函数创建了一个新的实例,这个实例拥有Object默认的方法如toString、toLocaleString等。

以上是关于Object.create()和new 创建对象的区别的主要内容,如果未能解决你的问题,请参考以下文章

Object.create()和new 创建对象的区别

js 中 new 与 Object.create()的区别

使用“Object.create()”而不是“new”关键字来理解原型对象的创建

JS中new与Object.create()的区别深入解析

JavaScript对象

js继承问题