如何在出现时以编程方式触发 NavigationLink
How to trigger a NavigationLink programmatically on appear
我试图在出现时以编程方式触发 NavigationLink,但在所有情况下目标视图在出现后立即弹出 (iOS 13.3.1, Xcode 11.3.1)
。
设置如下:ContentView 有一个到 DetailView1 的 NavigationLink,而 DetailView1 又有一个到 DetailView2 的 NavigationLink。我希望在首次加载 DetailView1 时自动触发 DetailView1 中的 NavigationLink(在我的实际代码中,这将基于条件,但这与此处无关)。
这是基本代码(没有自动行为):
import SwiftUI
struct ContentView: View {
var body: some View {
NavigationView {
NavigationLink(destination: DetailView1()) {
Text("Open Detail View 1")
}
.navigationBarTitle(Text("ContentView"))
}
}
}
struct DetailView1: View {
@State private var isActive = false
var body: some View {
VStack {
NavigationLink(destination: DetailView2(), isActive: $isActive) {
EmptyView()
}
Button ("Open Detail View 2") {
self.isActive = true
}
}
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
}
}
struct DetailView2: View {
var body: some View {
Text("This is Detail View 2")
.navigationBarTitle(Text("Detail View 2"), displayMode: .inline)
}
}
我的第一个方法是在 DetailView1 中的声明中将 isActive
设置为 true:
@State private var isActive = true
果然触发了NavigationLink,但是DetailView2一出现就弹出
我也(或者)尝试在 .onAppear
中将 isActive
设置为 true
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
self.isActive = true
}
结果是一样的。
实际起作用的是将 isActive
设置为 true 至少延迟 0.75 秒,我认为这不是一个可接受的解决方法。
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
DispatchQueue.main.asyncAfter(deadline: .now() + 0.75) {
self.isActive = true
}
}
这是一个错误还是有什么方法可以达到预期的效果?
使用 Xcode 11.4 / iOS 13.4 使用 .toggle()
可以正常工作,如下所示
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear {
self.isActive.toggle()
}
我试图在出现时以编程方式触发 NavigationLink,但在所有情况下目标视图在出现后立即弹出 (iOS 13.3.1, Xcode 11.3.1)
。
设置如下:ContentView 有一个到 DetailView1 的 NavigationLink,而 DetailView1 又有一个到 DetailView2 的 NavigationLink。我希望在首次加载 DetailView1 时自动触发 DetailView1 中的 NavigationLink(在我的实际代码中,这将基于条件,但这与此处无关)。
这是基本代码(没有自动行为):
import SwiftUI
struct ContentView: View {
var body: some View {
NavigationView {
NavigationLink(destination: DetailView1()) {
Text("Open Detail View 1")
}
.navigationBarTitle(Text("ContentView"))
}
}
}
struct DetailView1: View {
@State private var isActive = false
var body: some View {
VStack {
NavigationLink(destination: DetailView2(), isActive: $isActive) {
EmptyView()
}
Button ("Open Detail View 2") {
self.isActive = true
}
}
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
}
}
struct DetailView2: View {
var body: some View {
Text("This is Detail View 2")
.navigationBarTitle(Text("Detail View 2"), displayMode: .inline)
}
}
我的第一个方法是在 DetailView1 中的声明中将 isActive
设置为 true:
@State private var isActive = true
果然触发了NavigationLink,但是DetailView2一出现就弹出
我也(或者)尝试在 .onAppear
isActive
设置为 true
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
self.isActive = true
}
结果是一样的。
实际起作用的是将 isActive
设置为 true 至少延迟 0.75 秒,我认为这不是一个可接受的解决方法。
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
DispatchQueue.main.asyncAfter(deadline: .now() + 0.75) {
self.isActive = true
}
}
这是一个错误还是有什么方法可以达到预期的效果?
使用 Xcode 11.4 / iOS 13.4 使用 .toggle()
可以正常工作,如下所示
.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear {
self.isActive.toggle()
}