我在 SwiftUI 中开发了一个 macOS 个人理财应用程序,它通过 SwiftUI 和 AppKit 之间的
NSViewControllerRepresentable
接口使用 NSTableViews 和 NSOutlineViews。
我发现 AppKit 视图功能远远优于我使用 SwiftUI 列表创建的任何东西,而且它们运行速度更快并支持 TypeSelect。将数据传递到 Appkit ViewControllers 很简单,但获取信息似乎没那么简单。
Apple 开发人员文档建议我应该使用
Coordinator
类,我尝试这样做但无济于事。我需要的委托方法 (func tableViewSelectionDidChange(_ notification: Notification)
) 无法运行(从我的 Coordinator
类中)。
目前,我正在使用
NotificationCenter.default
交换数据和操作,效果很好,但我热衷于使用“官方”方法。我找到了一个成功使用 Coordinator 的 macOS 应用程序(在 https://www.markusbodner.com/til/2021/02/08/multi-line-text-field-with-swiftui-on-macos/),但是我无法让我的 Coordinator
类作为 NSTableViewDelegate
工作,即使它构建和运行没有错误(Xcode 12.4)。
我一开始想要做的就是获得一个包含
NSViewController
的 NSTableView
,只要用户在 NSTableView 中选择一个新行,就可以通过 NSTableView.selectedRow
将 Coordinator
传递到其父 SwiftUI 视图中。谁能帮忙(如果可能的话,请提供一些示例代码)?
我似乎找到了解决我自己问题的方法。我一直在
NSTableViewDelegate
功能中将我的 makeNSViewController
分配给协调员。但是,在填充我的NSTableView
的NSTableView
内容的代码运行之前(在NSTableViewDataSource
函数中),我的updateNSViewController
似乎没有被实例化。结果没有NSTableViewDelegate
分配。
将
tableVC.tableView?.delegate = context.coordinator
移动到 updateNSViewController
函数中,按照填充我的 NSTableViewDataSource
内容的代码,使我的 NSTableViewDelegate
按预期工作,并且 tableView.selectedRow
值现在通过 func tableViewSelectionDidChange(_ notification: Notification)
传递到我的父 SwiftUI 视图成功地。欢呼!
注意到我在
NSTableView
中使用 Cocoa 绑定可能很有用,并且发现有必要在 ViewController(文件所有者)并将这些函数的副本(当然是用代码填充)放在我的 Coordinator 类中,以使它们的代码按预期执行。生成的整体代码比我的旧代码简洁得多,它使用通知在 SwiftUI 和 AppKit 之间传递操作和数据 - 所以“官方”方法看起来是最好的。