使用Object.Create向JavaScript对象添加函数

时间:2012-11-26 12:56:56

标签: javascript oop object-create

我正在尝试在JavaScript中使用Object.Create。我目前有以下代码:

var vehicle = {
        getModel: function () {
        console.log( "The model of this vehicle is.." + this.model );
    }
};

var car = Object.create(vehicle, {
    "id": {
       value: 9,         
    },
    "model": {
       value: "Ford",  
    }
});

var van = Object.create(vehicle, {
  "id": {
     value: 10,    
   },
    "model": {
      value: "Big Van",
      enumerable: true
   },
    "make": {
      value: "Warrior",      
   },
    "getMake": function () {
       console.log( "The make of this vehicle is.." + this.make );
   }
});

我尝试为getMake添加一个函数,但是我收到了错误:

  

TypeError:对象#的属性'getMake'在我调用时不是函数:

van.getMake();

这可能吗?你是怎么做到的?

2 个答案:

答案 0 :(得分:6)

默认情况下,以这种方式创建的属性不可枚举。这可能会导致您的问题。

试试这个(未经测试):

"getMake": { value: function () {
       console.log( "The make of this vehicle is.." + this.make )
   }, enumerable: true };

编辑看起来这是有效的,因为我们传递的是一个对象,而不仅仅是值。可枚举是不必要的。

答案 1 :(得分:2)

您需要传递定义属性的对象,而不仅仅是值:

 "getMake": {value:function () {
     console.log( "The make of this vehicle is.." + this.make );
 }}

Reference

请注意,在Javascript中执行OOP的常用方法不是使用Object.create,而是使用prototype