[英]MVP view/presenter registration
我正在为WinForms应用程序开发基于MVP的GUI体系结构,并希望使用Autofac来跟踪不同的部分。 我一直遇到循环组件依赖关系,并希望朝着正确的方向轻轻地推动。
该架构基于这篇文章,在此文章中,View与我一样被动。 视图不引用演示者。 视图将在构造时传递给Presenter。 因此,在非DI世界中,您将使用以下代码启动程序:
var MainView = new MainView();
var mainPresenter = new MainPresenter(mainView, new DataRepository());
Application.Run(mainView);
好的,因此Presenter需要了解View实例才能完成其工作。 如何在注册码中表达出来? 这是我尝试过的:
builder.RegisterType<MainPresenter>().PropertiesAutowired().SingleInstance();
builder.RegisterType<MainView>().As<IMainView>().PropertiesAutowired().SingleInstance();
然后在Program.cs中:
var mainPresenter = Container.Resolve<MainPresenter>();
Application.Run(Container.Resolve<IMainView>() as MainView);
但是通过这种方式,我需要记住创建Presenter实例。 但是,我想在注册中表示,如果我请求IMainView实例,则应将MainPresenter付诸行动。 但是...
任何暗示,嘲弄或嘲笑的欢迎
我认为您应该可以这样解决:注册演示者和视图而无需注入属性,因为您说视图不需要引用演示者,并且构造函数注入被认为是Autofac的最佳实践:
builder.RegisterType<MainPresenter>().SingleInstance();
builder.RegisterType<MainView>().As<IMainView>();
通过构造函数将视图注入到presenter中,并将其发布为只读属性:
public class MainPresenter
{
// Private variables
private readonly IMainView _view;
// Constructor
public MainPresenter(IMainView view)
{
_view = view;
}
// Properties
public IMainView View
{
get { return _view; }
}
}
然后,您通过一个解决方案启动应用程序:
var mainPresenter = Container.Resolve<MainPresenter>();
Application.Run(mainPresenter.View as Form);
最后,如果以后发现您需要从视图到演示者的引用,我认为您必须在视图上使用属性注入以避免循环引用异常。 然后,您可以像这样注册视图:
builder.RegisterType<MainView>().As<IMainView>().PropertiesAutowired(PropertyWiringFlags.AllowCircularDependencies);
并为视图提供由Autofac设置的读/写属性
public MainPresenter Presenter { get; set; }
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.