1.对象字面量

最常用的最方便的创建方法,如下所示

var foo = {
    bar: 'bar'
}

其实字面量是使用object.create的快捷方式,下面代码与上面等价

var foo = Object.create(Object.prototype,{
    bar: {
        writable: true,
        configurable: ture,
        value: 'bar'
    }
})

2.new Object()

var Person = function(myname){
    this.name = myname;
}
var me = new Person('Joe');

当我们讨论到new Object(),实际上我们在讨论new运算符,new运算符实际上做了一下工作

2.1创建一个新对象

me = {}

2.2将新创建的对象的构造函数链接到函数Person上

//true
me.constructor === Person

2.3将对象的原型链链接到Person.prototype

使新建对象可以沿原型链使用构造函数的方法

//true
me.__proto__ === Person.prototype

2.4将传入的参数富裕给新创建的对象

3.Object.create(ES5)

在ES5之前,只能使用new来实现原型链集成。总而言之Object.create()和字面量对象应该替换new object()方法。
Object.create()可以接收两个参数:提供原型的对象,可选属性对象(这个对象包含对新创建对象的配置)。

var Car = {
    drive: function (miles) {
        return this.odometer += miles;
    }
};
var tesla = Object.create(Car, {
    'odometer': {
        value: 0,
        enumerable: true
     }     
));

//输出10
console.log(tesla.drive(10));

ssshooter
3.7k 声望1.8k 粉丝