Кнопка с NavigationLink и вызовом функции SwiftUI

У меня проблема с условиями NavigationLinks. Он не реагирует на то, что я ожидал. Когда пользователь нажимает на кнопку, должна вызываться функция «тест» и выдавать возвращаемое значение. Если возвращаемое значение истинно, «SheetView» должен открываться напрямую, не нажимая на текст NavigationLink. Пожалуйста, помогите мне в этом. заранее спасибо

Я сделал небольшую (примерную) программу для демонстрации проблемы.

      import SwiftUI

struct LoginView: View {
   @State var check = false
   @State var answer = false
   
    var body: some View {
       NavigationView {
         VStack{
            Text("it doesn't work")
            Button(action: {
                answer = test(value: 2)
                if answer {
                    //if the return value is true then directly navigate to the sheetview
                    NavigationLink(
                        destination: SheetView(),
                        label: {
                            Text("Navigate")
                        })
                }
            }, label: {
                Text("Calculate")
            })
            
        
         }
       }
    }
    
    func test(value: Int) -> Bool {
     
            if value == 1 {
                check = false
            } else {
                print("Succes")
                check = true
            }
        
        return check
    }
       
}


struct SheetView: View {

    var body: some View {
        NavigationView {
            VStack{
                Text("Test")
                    .font(.title)
            }
        }
    }
}

3 ответа

Решение

Ответ от Yodagama работает, если вы пытались представить лист (потому что вы вызвали место назначения для навигации SheetView), но если вы пытались перейти к SheetView вместо того, чтобы представить лист, следующий код сделает это.

      struct LoginView: View {
   @State var check = false
   @State var answer = false
   
    var body: some View {
       NavigationView {
         VStack{
            Text("it doesn't work")
            NavigationLink(destination: SheetView(), isActive: $answer, label: {
                Button(action: {
                    answer = test(value: 2)
                }, label: {
                    Text("Calculate")
                })
            })
            
            
        
         }
       }
    }
    
    func test(value: Int) -> Bool {
     
            if value == 1 {
                check = false
            } else {
                print("Succes")
                check = true
            }
        
        return check
    }
       
}


struct SheetView: View {

    var body: some View {
        NavigationView {
            VStack{
                Text("Test")
                    .font(.title)
            }
        }
    }
}
      @State private var route: Bool = false

// use the modifier for the button    

.navigationDestination(isPresented: $route, destination: {
            DestinationView()
        }

// and wrap the parent view in NavigationStack 
      struct LoginView: View {
   @State var check = false
   @State var answer = false
   
    var body: some View {
       NavigationView {
         VStack{
            Text("it doesn't work")
            Button(action: {
                answer = test(value: 2)
                //<= here
            }, label: {
                Text("Calculate")
            })
            
        
         }
         .sheet(isPresented: $answer, content: {  //<= here
            SheetView()
         })
       }
    }
    
    ...
Другие вопросы по тегам