微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 如何在Caliburn.Micro中将依赖项注入视图模型?

我真的希望这不是一个愚蠢的问题,但我无法识别使用Caliburn.Micro将依赖关系注入视图模型的直接方法.

我有一个像这样的主壳(导体):

public class Shellviewmodel : Conductor<IScreen>.Collection.OneActive,IShell
{
    public Shellviewmodel(IEventAggregator eventAggregator) {
        ActivateItem(new Dashboardviewmodel());
    }
}

现在我想将一个服务注入Dashboardviewmodel,但由于ActivateItem方法要求我传递一个实例(而不是一个类型),我不得不自己提供服务.由于Shellviewmodel不知道底层IoC容器,我必须将服务注入shell …对我来说,看起来Caliburn正在尝试强制执行应用程序中所有视图模型和依赖项的完整图形.

我知道我可以使用静态访问器来控制容器的反转,但我真的不喜欢这种方法,因为我想为我的应用程序(引导程序)创建一个组合根,而不需要知道其他部分关于依赖注入等.

解决方法

几种方法可以完全依赖于您选择的容器.

MEF [ImportMany]在构造函数中使用的参数将执行实际导入引用Hello Screens示例

在IoC静态类中,您可以使用IoC.Get< IDashBoard>()或IoC.GetAll< IDashBoard>(),这假设您已将类型注册到您使用的容器中.注意这个可以过度使用并导致反模式行为.我在我的一个执行仪表板的应用程序中执行了此操作,在我的Container实例中使用IDashBoard标记的任何内容与实际实现类相关联将被拉入集合IoC.GetAll< IDashboard>()或第一项在基于IoC.Get< IDashBoard>()的集合中.

您还可以使仪表板继承Conductor< IDashBoard> .Collection.AllActive,允许您访问Items属性(作为Collection的一部分),并使用IoC.GetAll< IDashboard>填充DashBoardviewmode的CTOR( )在那个地方获得仪表板上所需的所有物品.从那里,我查询OnActivate中的Items集合属性,并将其他viewmodels与我需要的属性相匹配,并相应地在DashBoardView上放置名为ContentControls.

这确实是从您选择的容器中拉出来的,记住您可能只想要容器的方法来通过其预期的设计获取必要的物品.

我实际上离开了MEF,因为CM中使用的版本不适用于Open Generics并且调试缺少Export()属性开始让我疲惫不堪.

原文地址:https://www.jb51.cc/csharp/99395.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐