我有一个Caliburn.Micro MVVM框架的启动程序,在这里我只自动注册程序集中的所有ViewModels。
有些ViewModels有带有参数的构造函数,在完成自动注册之后,我通常会手动重写这些构造函数(使用Register-parameter ifAlreadyRegistered: IfAlreadyRegistered.Replace)。
但是,当ViewModel具有基本类型时,DryIoc会自动使用默认值填充该类型。
然后,当我用正确的参数手动注册ViewModel时,我会得到相同ViewModel的两个注册,其中Caliburn.Micro将选择默认填充的一个。
建议的处理这些东西的方法是什么?
更新:
ctor ViewModel(DependencyA depA, string[] list)
AssemblySource.Instance.SelectMany(Portable.GetAssemblyTypes)
.Where(type => type.Name.EndsWith("ViewModel"))
.ForEach(type => _container.Register(type));这将注册为ServiceKey=DefaultKey.Of(0) registered as factory
因此,我现在知道了应该是什么列表(在自动注册之后),并且再次注册ViewModel,这一次使用一个与实际string[]链接的不同的服务键。
Container.Register<ViewModel>(
made: Parameters.Of.Type<IEnumerable<string>>(typeof(string[])),
serviceKey: "list");这将导致另一个注册with ServiceKey="list" registered as factory。我希望这个命名注册取代默认的,但我必须保留名称,以实际填充列表。
原因是: Caliburn.Micro将尝试按类型解析,并且我必须显式地使用IoC.Get<>()来提供密钥,这意味着我无法在构造函数中注入ViewModel。
发布于 2016-06-22 10:21:59
作为第一次尝试,您可以尝试直接解决问题:通过使用容器范围的工厂选择器规则SelectKeyedOverDefaultFactory。
var c = new Container(Rules.Default
.WithFactorySelector(SelectKeyedOverDefaultFactory("preferable key")));
c.Register<I, A>();
c.Register<I, B>(serviceKey: "preferable key");
c.Resolve<I>(); // will resolve I of B
c.Register<X>();
c.Resolve<X>(); // will work as before (w/out rule) by falling back to default factory.但是我计划在下一个版本中解决这种情况。
https://stackoverflow.com/questions/37961018
复制相似问题