我有两个像这样定义的对象(为了问题而简化):
var firstObject = function(){ };
firstObject.prototype.doSomethingFirstObjectsDo();
var secondObject = function(){ };
secondObject.prototype.doSomethingSecondObjectsDo();
接下来我有一个对象管理器,它作为我的主应用程序创建对象的一种接口:
var ObjectManager = function()
{
this.create = {
FIRST:firstObject,
SECOND:secondObject
};
};
ObjectManager.prototype.createObject = function(type)
{
return new this.create[type]();
};
最后使用对象管理器动态创建firstObjects或secondObjects的主应用程序示例:
var MainApplication = function(options)
{
this.objectTypes = options.objectTypes;
this.objManager = new ObjectManager();
};
MainApplication.prototype.createObjects = function()
{
//Iterate through all the types this application needs to create
for (var type in this.objectTypes)
{
var dynamicallyCreatedObject = this.objManager.createObject(type);
//Do Something Else
}
};
这种方法效果很好,但是我可以看到一个缺点 - 你需要为每个可以创建的对象“Type”正式定义构造函数的名称。
如果我想创建一个“thirdObject” - 它已经正式定义 - 我还需要返回并在ObjectManager中添加对“thirdObject”的构造函数的引用。
理想情况下,我想删除对“ObjectManager”的需求,并且只需能使用“new”关键字动态调用构造函数方法,如下所示:
//Inside MainApplication
for (var type in this.objectTypes)
{
var dynamicallyCreateObject = new [type](); //Invalid Syntax
};
有人对使用“new”关键字在JavaScript中动态创建不同对象的更好方法有任何想法吗?
回应一些初步评论:
我应该提到整个应用程序都包含在一个匿名函数中。
(function(){
//All of My Mentioned Code is Found Here
$(document).ready(function(){
mainApp = window.mainApp = new MainApplication(options);
});
});
@casablanca:从你所说的我相信我需要在整个匿名函数中实际定义一个NameSpace,因为一旦完成,我就没有真正的方法可以再次直接引用该范围。我想我知道我现在需要做什么,我有点希望有另一种方法可以使用这个“新”关键字 - 但似乎并非如此。
答案 0 :(得分:8)
此:
var dynamicallyCreateObject = new [type]();
几乎是正确的,除了你需要一个外部对象来访问属性。如果构造函数是全局的,则可以使用window
:
var dynamicallyCreateObject = new window[type]();
理想情况下,它们应该在您自己的命名空间内,在这种情况下,您可以执行类似的操作:
var dynamicallyCreateObject = new MyNamespace[type]();
答案 1 :(得分:4)
假设我理解你的愿望(而且我不确定我是谁)你可以在DOM 0浏览器中使用全局window
对象,或者创建自己对全局范围的引用,并使用它来查看在本地定义的变量。
var $global = this;
var firstObject = function(){};
var objName = "firstObject";
var instance = new $global[objName];