如何解决如何定义一个变量,我的对象中的所有函数都可以访问该变量?
| 我有一个这样的对象: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/
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。