导航链接视图参数 SwiftUI

6

当我在我的视图中调用 NavigationImageView 时,我希望每次调用都能发送不同的视图,这样我就可以导航到不同的视图。但问题是如何在 NavigationLink 中发送视图参数。我尝试使用 View 和 UIView,但会出现错误。

struct NavigationImageView: View {
    
    var item : Store
    var destinationView: View
    
    var body: some View {
        
        NavigationLink(destination:destinationView ) {
            
            Image(uiImage: (item.banner?.url)!.load())
                .resizable()
                .aspectRatio(CGFloat((item.banner?.ratio)!), contentMode: .fit)
                .cornerRadius(12)
                .shadow(radius: 4)
                .frame(width: CGFloat(UIScreen.main.bounds.width * 0.9), height: CGFloat((UIScreen.main.bounds.width / CGFloat((item.banner?.ratio) ?? 1))))
            
        }
    }
}
2个回答

6
你需要在这里使用泛型,因为目标视图的类型事先不知道:
struct NavigationImageView<DestinationType: View>: View {
    
    var item : Store
    var destinationView: DestinationType

    // ... other code
}

2

看下面的例子...

您的属性必须是任何视图,然后您可以将任何视图分配给它,以便用作目标。

import SwiftUI

struct ContentView: View {
    
    @State var showViewTwo : Bool = false
    
    //computed property of type some View which returns different views depending on a condition
    var destination : some View { 
        if showViewTwo {
            return Text("Hello Second View")
        }
        else
        {
            return Text("Hello First View")
        }
    }
    
    var body: some View {
        
        NavigationView {
           NavigationLink("Press me", destination: destination)
        }
        
        Button(action: {
            showViewTwo.toggle()
        }) {
            Text("Toggle View")
        }
        
    }
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接