2

我试图在出现时以编程方式触发 NavigationLink,但在所有情况下,目标视图都会在出现后立即弹出(iOS 13.3.1, Xcode 11.3.1)

设置如下:ContentView 有一个到 DetailView1 的 NavigationLink,而后者又具有一个到 DetailView2 的 NavigationLink。我希望 DetailView1 中的 NavigationLink 在 DetailView1 首次加载时自动触发(在我的实际代码中,这将基于一个条件,但这在这里无关紧要)。

这是基本代码(没有自动行为):

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)
    } 
}

我的第一种方法是isActive在 DetailView1 中的声明中设置为 true:

@State private var isActive = true

正如预期的那样,NavigationLink 被触发,但 DetailView2 出现后立即弹出。

我也(或者)尝试isActive在内部设置为 true.onAppear

.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
    self.isActive = true
}

然而结果是一样的。

实际起作用的是将设置延迟isActive至少 0.75 秒,我认为这不是可接受的解决方法。

.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear(){
    DispatchQueue.main.asyncAfter(deadline: .now() + 0.75) {
        self.isActive = true
    }
}

这是一个错误还是有办法达到预期的效果?

4

1 回答 1

-1

使用 Xcode 11.4 / iOS 13.4 可以正常使用.toggle(),如下所示

.navigationBarTitle(Text("Detail View 1"), displayMode: .inline)
.onAppear {
    self.isActive.toggle()
}

演示

于 2020-03-22T09:21:25.563 回答