根据Document-Based Applications Guide,应该有一个 DocumentController、一个 Document 和一个 WindowController。我遇到的麻烦是学会判断给定的责任应该落在哪里。
我的文档代表一个待办事项列表。给定的待办事项列表由我的 Document 读入内存,并由 WindowController 显示。任何时候可以放入窗口的待办事项的数量取决于窗口的大小,所以当我需要显示待办事项时,我的 WindowController 会要求我的 Document 提供足够的待办事项来填充可见列表。
如果我愿意,我可以使用正则表达式搜索我的待办事项(我知道,很不错),匹配项将作为顶部结果返回。在这种情况下,我不太清楚责任在哪里。Document 处理保存和加载待办事项列表,但在上面我要求它还处理将列表的一小部分返回给 WindowController。那么匹配逻辑是否应该放在 Document 中?还是应该保留在 WindowController 中,因为它与保存和加载数据无关(搜索后待办事项的顺序永远不会保存到磁盘)?这些是我发现自己问(我自己)的问题。当我回顾这样一个项目时,我注意到我的判断调用似乎相互矛盾的地方。有时我会花一个小时在两者之间移动一点逻辑......
显然我需要帮助。
我的例子是一个非常特殊的情况,但我对特定的解决方案不感兴趣。我有兴趣更笼统地了解这三个类的职责应该是什么。我阅读了该指南,并在谷歌上搜索了一下,但我似乎仍然无法掌握它。
这个问题很有帮助,但我仍然感到困惑。
谢谢!