问题描述
|
我有一个这样的对象:
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 \”子对象)的不同函数中使用。
我想知道,在哪里可以在myobj
中定义Car car=new Car();
,以便使car
定义一次,并且可以在myobj
中的多个函数中使用。
解决方法
您可以这样做:
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/