得到了两个Javascript文件,让我们说A
和B
。
一个包含在另一个中-B
使用A
文件中的对象。
首先在我的debug
函数中创建AConfig
对象,
然后创建BElementBuilder
,它使用ABuilder
和AConfig
对象;
目前一切正常。
但是,当我呼叫bElement.getBString
时,它进入了内部,并在me.aBuilder.getAString(Aconfig);
上失败并出现错误
对象不支持此属性或方法
为什么会这样呢?
这是A
var AConfig = (function() {
function AConfig(name, flag){
this.name = (name) ? name : -1;
this.flag = (flag) ? true : false;
return this;
}
return AConfig;
})();
var ABuilder = (function() {
function ABuilder(config){
this.config = (config) ? config : new AConfig();
return this;
};
ABuilder.prototype = {
getAString: function(configObj){
var me = this,
config = (configObj) ? configObj : me.config,
name = me.name,
flag = me.flag;
return 'A name is' + name + 'flag =' + flag;
}
}
return ABuilder;
});
这是
B
:!INC aFile.A
var BElementBuilder = (function() {
function BElementBuilder(aConfig, bName){
this.aConfig = (aConfig) ? aConfig : new AConfig();
this.bName = (bName) ? bName : "B";
this.aBuilder = new ABuilder();
return this;
};
BElementBuilder.prototype = {
getBString: function(configObj){
var me = this,
Aconfig = (configObj) ? configObj : me.aConfig,
name = me.bName;
//and here it fails
Aconfig = me.aBuilder.getAString(Aconfig);
return 'B has config of' + Aconfig;
}
}
return BElementBuilder;
})();
function debug(){
var aConfig = new AConfig("AAA", true);
var bElement = new BElementBuilder(aConfig);
var t = bElement.getBString(aConfig);
};
debug();
附言
如果有任何区别,则为
JScript
最佳答案
您忘记了ABuilder
模块上的IIFE调用。这样,ABuilder
不是类构造函数,而是返回新构造函数的模块工厂函数。当您将其称为new ABuilder();
时,它将返回一个分配给bElement.aBuilder
的构造函数,而不是您期望的空白。