就像 dkatzel 所说,使用factory。这就是我的做法。如果您正在创建例如 BaseViewModel:
的实例
public interface IViewModelFactory {
T Create<T>() where T : BaseViewModel;
}
public class ViewModelFactory : IViewModelFactory {
private readonly Dictionary<Type, Func<BaseViewModel>> _factories;
public ViewModelFactory(Dictionary<Type, Func<BaseViewModel>> factories) {
_factories = factories;
}
public T Create<T>() where T : BaseViewModel {
return _factories[typeof (T)]() as T;
}
}
所以现在我们有一个可注入工厂,可以配置为创建和返回任何实现 BaseViewModel 的东西。
在 IoC 中,我们需要配置要返回的类型,因此想象一下这些视图模型(并注意第二个视图模型中的依赖关系):
public abstract class BaseViewModel {
// ...
}
public class FirstViewModel : BaseViewModel {
// ...
}
public class SecondViewModel : BaseViewModel {
private readonly ISomeDependency _injectedDependency;
public SeoncdViewModel(ISomeDependency dependency) {
_injectedDependency = dependency;
}
}
并且(使用 Autofac)我们这样配置它:
var builder = new ContainerBuilder();
builder.Register(b => {
var factories = new Dictionary<Type, Func<BaseViewModel>> {
{ typeof (FirstViewModel), () => new FirstViewModel() },
{ typeof (SecondViewModel), () => new SecondViewModel(b.Resolve<ISomeDependency>()) },
};
return new ViewModelFactory(factories);
}).As<IViewModelFactory>();
现在我们可以注入IViewModelFactory 并创建FirstViewModel 或SecondViewModel 的实例:
public class SomeClass {
public readonly IViewModelFactory _factory;
public SomeClass(IViewModelFactory factory) {
_factory = factory;
var secondViewModel = _factory.Create<SecondViewModel>();
}
}
好的部分是 IoC 处理所有依赖项。 SomeClass 只知道它有一个可以创建SecondViewModel 的东西,所以SomeClass 不需要知道SecondViewModels 的依赖关系。