2

我有一个很大的组件。我们也可以假设它是主要组件。这个组件应该包含一个子组件,在我的例子中它是一个抽象面板,并且它已经实现了自己的 MVP。现在我正在实现 MainComponent,因此我需要生成小型可重用抽象子组件的 MVP。

我现在的问题是:我应该在哪里生成 3 个子部分中的每一个?视图中的视图和模型中的演示者+模型?视图中的视图,演示者中的演示者,模型中的模型?

提前感谢您对此的意见!

MVP(被动视图)

4

1 回答 1

0

您没有提供有关 MVP 的具体实现的太多细节,但这是我对这个主题的想法:

它已经实现了自己的 MVP

我假设这意味着当加载视图(无论是主视图还是子视图)时,它已经与正确的演示者和模型连接起来。我还假设,如果任何子演示者与主演示者共享组件或服务,这些都由依赖注入框架解决。

如果我的假设不正确,那么应该更新负责加载视图的组件以确保发生这种情况,即,当加载视图时它可以正常工作。

我现在的问题是:我应该在哪里生成 3 个子部分中的每一个?视图中的视图和模型中的演示者+模型?视图中的视图,演示者中的演示者,模型中的模型?

根据我上面的评论,您应该有一个对象负责加载视图并确保它们被正确配置(让我们将此对象称为ViewLoader)。该对象只能直接从您的视图层调用,即从不从演示者调用。

但问题在于演示者对象驱动应用程序,因此需要一种告诉视图层加载另一个视图的方法。您可以通过将视图引用传递给演示者来解决此问题。视图引用应该隐藏在一个不暴露所使用的视图技术的任何细节的接口后面,例如:

public interface IMainView
{
    void OpenSettings();
}

然后您的演示者可以调用该OpenSettings()方法。该方法将由具体的视图类实现,可能如下所示:

public class MainView : UserControl, IMainView
{
    public void OpenSettings()
    {
        var settingsView = viewLoader.Load(typeof(settingsView));
        this.tabControl.add(settingsView);
    }
}

请注意,实现该接口的实际具体视图可以使用ViewLoader加载视图,因此它只需要关注将视图插入到视图层次结构中(因为ViewLoader已经提供了完全配置的视图)。

还要注意,IMainView接口描述了应用程序的行为,而不是实际的实现(即,它被命名OpenSettings而不是OpenDialog)。这意味着如果视图改变了它打开设置视图的方式(例如在对话框中显示它),那么只需要更新视图;演示者根本不需要更改,因为它仍然会调用该OpenSettings()方法来调用所需的行为。

总之:

  • 演示者调用视图上的方法来驱动行为。
  • 视图隐藏在一个界面后面以隐藏视图技术的细节。
  • 视图加载器负责加载视图并将它们连接到它们的模型和演示器。
  • 视图要求视图加载器加载所需的视图,并负责显示返回的、完全配置的视图。
于 2014-08-14T11:17:27.007 回答