gpt4 book ai didi

java ;多个 MVC 和 Swing 关系最佳实践?

转载 作者:行者123 更新时间:2023-12-01 14:36:45 24 4
gpt4 key购买 nike

我正在尝试使用带有 Observer/Observable 的 MVC 设计范例来开发“人员数据库”Java Swing 应用程序。以下是我正在使用的 M/V/C 的简化摘要:

App
AppModel
(Empty right now, possibly i'll store certain static application info such as version number here)
AppView
(Creates a JFrame and a few other Swing components)
AppController
(Instantiates AppModel, AppView and also a PersonController and a PersonListController)

Person

PersonModel
(Stores info for 1 person)

PersonView
(Displays a number of form fields inside a JPanel (i.e Name, Age, Phone number). Observes PersonModel.)

PersonController
(Instantiates PersonView. Observes PersonView. Instantiates PersonModel. Updates PersonModel.)

PersonList

PersonListModel
(Stores a list of Persons)

PersonListView
(Displays a list of persons with appropriate Add / Delete buttons. Observes PersonList.)

PersonListController
(Instantiates PersonListView. Observes PersonListView. Instantiates PersonListModel. Updates PersonListModel)

此外,还有一个“ Bootstrap ”,应用程序启动的地方。它创建一个新的 AppController。

在实际应用程序中,将会有更多(且不同)的模型/ View / Controller 对象,但我想让这个示例保持简单。

我不明白如何将这些单独的 View “合并”到一个 UI 中,同时保持良好的关注点分离。

以 PersonListView 为例。恕我直言,它不需要关心 AppView(使用 JFrame 等)。 PersonListView 只需查看其自己模型并相应地更新自身。但是,我无法强制执行这一点,因为需要将 PersonListView 自己的 Swing 组件添加到另一个 View (AppView)的 Swing 组件中。

因此,目前 AppController 正在实例化自己的 View,以及间接的 PersonView 和 PersonListView(通过其 Controller 的实例化)。然后,AppController 获取每个 View 的“主”Jpanel,获取应添加到 AppView 上的“父”Swing 组件,然后添加它们。

这对我来说似乎不是正确的方法。我将与 Swing 相关的成员从他们的藏身之处拉出来,并在 Controller 内搞乱他们。事实上,在 Controller 中实例化模型和 View 似乎也很糟糕,但我想不出更好的方法。

我最近看了足够多的“简单 MVC”教程,以至于我梦想着那些该死的事情 - 但似乎没有一个教程涉及多个模型、 View 、 Controller 的关系,尤其是涉及 Swing 的地方。也许我错了,应用程序应该只有一种 View ?也许我需要一个“关系”类来获取每个模型/ View / Controller 并适本地实例化东西?

任何建议将不胜感激,因为我完全不知所措!

最佳答案

这就是严格的 MVC 范式失败的地方(无论如何在 Swing 中,它可以解释为什么 Swing 是这样编写的)。

Swing 将 View 和控制元素组合在一起,而将模型分开。这意味着,您可以自由地将 View 添加到任何其他 View ,并且控件会跟随(模型保持动态)。

我有一个开发人员坚持使用严格的 MVC 方法,但他们仍然无法告诉我优先顺序。即控件应该了解 View 还是 View 应该了解控件 - 哪个插件插入另一个控件。就我个人而言,我很懒,只是遵循 Swing 实现。

在我看来,如果您想遵循严格的 MVC,我基本上会允许在 Controller 中使用公共(public)方法,该方法允许访问整体 View (例如包含所有组件的 JPanel例如,它构成了 View )。

例如,考虑一下 JComboBoxJSpinner。它们都有许多组成 View 的组件(编辑器、按钮等),但您只有一个访问点,即组件本身......

您的下一个问题将是如何将各种 View 组合成一个整体 View 。

就个人而言,我会创建某种类型的组 Controller ,允许您一起提供各种已知的 Controller (例如 setPersonList),因为“主” Controller 将需要以任何方式了解这些其他 Controller ,因为它需要知道如何布局它们。

恕我直言

关于 java ;多个 MVC 和 Swing 关系最佳实践?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16425326/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com