我之前有以下代码,它工作正常。 (请注意,Card,SearchResults,Quiz都扩展为Persistable,而Persistable包含构造函数.fromMap
。
Persistable fromString(String value){
Map<String, dynamic> m = parse(value);
switch(m['type']){
case 'card':
return new Card.fromMap(m);
case 'searchresults':
return new SearchResults.fromMap(m);
case 'quiz':
return new Quiz.fromMap(m);
}
}
有点罗嗦,所以我想我会把它分成两部分。我首先有这个:
static final Map<String, Persistable> lookup =
{'card': Card,
'searchresults': SearchResults,
'quiz': Quiz };
似乎合理,但是当我尝试重新定义该方法时,我感到困惑。
Persistable fromString(String value){
Map<String, dynamic> m = parse(value);
String type = m['type'];
Persistable p = lookup[type];
... Confused, this can't be right
... ultimately want to "return new p.fromMap(m)";
}
Persistable p
实际上是指类Persistable
的实例。如何键入我的lookup
地图,使其值为Persistable
类,以便我可以调用他们的.fromMap
构造函数?
答案 0 :(得分:2)
首先,我认为你的初步方法是完全有效的,不应仅因其冗长而被抛弃。 我相信替代方法会带来额外的复杂性,只有在您真正需要动态调度时才有道理。 (例如,如果您为了持久性而编写库,并且希望为库的客户端添加为任意类注册任意类的能力) 如果动态调度对你来说是必须的,我相信有两个主要的可能性: - Reflection API。最近反射库得到了同步API,所以这种方式现在比以前更实惠。我相信无论如何反思总会产生一些成本。 - 使用核心DART功能。
使用第二种方法,您可以使用某种技巧来动态模仿构造函数调用。 例如,您可以在map中存储而不是Type变量,而是存储返回所需类的实例的函数:
所以你的代码看起来像
static final Map<String, Function> lookup = new Map<String, Function>
static void registerClass(String className, factory) {
lookup[className] = factory;
}
static Persistable getInstance(String className, Map map){
return lookup[className](map);
}
在客户端:
....
registerClass('quiz', (map)=> new Quiz.fromMap(map));
registerClass('card', (map)=> new Card.fromMap(map));
(注意 - 我没有测试过这个) 您可以在https://github.com/vadimtsushko/objectory
中查找该方法的工作示例代码