【发布时间】:2020-01-12 19:00:37
【问题描述】:
我看到 WatchOS 的基于页面的导航是 supported,但有没有办法使用 SwiftUI 访问此功能?
【问题讨论】:
-
我在此处发布了如何实现此作为另一个问题的答案的详细说明:stackoverflow.com/a/62392066/1687087
我看到 WatchOS 的基于页面的导航是 supported,但有没有办法使用 SwiftUI 访问此功能?
【问题讨论】:
如果您正在使用新的 SwiftUI App Lifecycle 并且无法访问 Storyboards(或者只需要 App Delegate Cycle 的解决方案而不使用 Storyboards),您可以在 SwiftUI 2 中使用新的 Page View 样式:
WindowGroup {
TabView {
Page1View()
Page2View()
}
.tabViewStyle(PageTabViewStyle())
}
【讨论】:
是的,这是可能的。首先,像这样为每个页面定义托管控制器
class Page1HostingController: WKHostingController<Page1View> {
override var body: Page1View {
self.setTitle("page1")
return Page1View()
}
}
class Page2HostingController: WKHostingController<Page2View> {
override var body: Page2View {
self.setTitle("page2")
return Page2View()
}
}
Page1View 和 Page2View 是您的 SwiftUI 实现。
然后,将新的视图控制器添加到您的Interface.storyboard,将它们的实现类设置为您的新控制器类并通过“下一页”segue 连接它们。
【讨论】:
有NavigationLink 按钮,按下时会触发导航演示。
var body: some View {
VStack() {
NavigationLink(destination: Text("Destination view"), label: {
Text("Title of the NavigationLink button")
})
}
}
【讨论】: