如何定义一个可以被我的对象中的所有函数访问的变量?

时间:2011-04-15 13:28:26

标签: javascript javascript-framework

我有一个这样的对象:

myobj={
  //where to define Car car=new Car();
  test:{
    testFunc1(){car.paintTest();},
    testFunc2(){car.drawTest();}
  },

  use:{
    useFunc1(){car.paintUse();},
    useFunc2(){car.drawUse();}
  },
};

我将使用myobj的方式,在另一个js文件中,我可以轻松调用

myobj.test.testFunc2();

myobj.use.useFunc1();

正如您所注意到的那样,在myobj中,我有一个car实例经常在不同子对象的不同函数中使用 (例如“test”,“use”子对象)。

我想知道,我在哪里可以在Car car=new Car();中定义myobj,以便car定义为一次,并且可以在几个< / strong> myobj中的函数。

1 个答案:

答案 0 :(得分:2)

你可以这样做:

myobj={
  car: new Car(),

  test: {
    var self = this;
    testFunc1(){self.car.paintTest();},
    testFunc2(){self.car.drawTest();}
  },

  use: {
    var self = this;
    useFunc1(){self.car.paintUse();},
    useFunc2(){self.car.drawUse();}
  },
};

<强>更新

带有假Car对象的工作版:

function Car (){
    this.paintTest = function(){console.log('painttest')}
    this.drawTest = function(){console.log('drawtest')}
    this.paintUse = function(){console.log('paintuse')}
    this.drawUse = function(){console.log('drawuse')}
}

myobj = {
  car: new Car(),

  test:{
      testFunc1: function() {myobj.car.paintTest();},
      testFunc2: function() {myobj.car.drawTest();}
  },

  use: {
      useFunc1: function(){myobj.car.paintUse();},
      useFunc2: function(){myobj.car.drawUse();}
  },
};

myobj.test.testFunc1();
myobj.test.testFunc2();
myobj.use.useFunc1();
myobj.use.useFunc2();

小提琴:http://jsfiddle.net/maniator/KcQvL/