LazyVGrid 内的 NavigationLink 循环背面的所有条目,SwiftUI

Dan*_*ini 9 ios swift swiftui

我有一个图像网格。点击的每个图像都应在 NavigationView 上推送一个包含图像详细信息的视图。

导航链接按预期工作,但是当我按后退按钮时,它会打开下一个图像,依此类推,直到循环所有图像。到底是怎么回事?

这是View

struct ImageGrid: View {
    
    @ObservedObject var part: Part
    @State private var showingImagePicker = false
    @State private var inputImage: UIImage?
    var body: some View {
        Button("add images"){
            self.showingImagePicker = true
        }
        LazyVGrid(columns: [GridItem(.adaptive(minimum:100))]){
            ForEach(part.images){ image in
                ZStack {
                    Image(uiImage: image.thumb)
                        .resizable()
                        .scaledToFit()
                    NavigationLink (
                        destination: ImageDetail(image:image),
                        label: {
                            EmptyView()
                        }
                    ).buttonStyle(PlainButtonStyle())
                }
            }
        }
        .sheet(isPresented: $showingImagePicker, onDismiss: loadImage) {
            ImagePicker(image: self.$inputImage)
        }
        
    }
    // other functions ...
    ...
}
Run Code Online (Sandbox Code Playgroud)

这就是细节View

struct ImageDetail: View {
    
    @ObservedObject var image: TrainingImage
    var body: some View {
        VStack {
            Image(uiImage: image.content)
                .resizable()
                .scaledToFit()
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

编辑:

这是一个隔离行为的独立示例。当网格位于表单部分内时,它似乎停止正常工作。消除导航链接正常工作的表单和部分

struct ImageGrid: View {
    
    @ObservedObject var part: Part
    @State private var showingImagePicker = false
    @State private var inputImage: UIImage?
    var body: some View {
        Button("add images"){
            self.showingImagePicker = true
        }
        LazyVGrid(columns: [GridItem(.adaptive(minimum:100))]){
            ForEach(part.images){ image in
                ZStack {
                    Image(uiImage: image.thumb)
                        .resizable()
                        .scaledToFit()
                    NavigationLink (
                        destination: ImageDetail(image:image),
                        label: {
                            EmptyView()
                        }
                    ).buttonStyle(PlainButtonStyle())
                }
            }
        }
        .sheet(isPresented: $showingImagePicker, onDismiss: loadImage) {
            ImagePicker(image: self.$inputImage)
        }
        
    }
    // other functions ...
    ...
}
Run Code Online (Sandbox Code Playgroud)

Asp*_*eri 7

它是表单/列表功能,可以自动检测行中的链接,但是您在行中有多个链接,所以效果不佳。解决方案是将单元格视图分开并隐藏自动检测的链接。

使用 Xcode 12.0 / iOS 14 进行测试

struct ContentView: View {
    @State var images:[String] = ["plus", "minus"]
    var body: some View {
        NavigationView {
            Form {
                Section {
                    LazyVGrid(columns: [GridItem(.adaptive(minimum:100))]){
                        ForEach(images){
                                    ImageCellView(image: $0)
                        }
                    }
                }
            }
        }
    }
}

struct ImageCellView: View {
    var image: String
    @State private var isActive = false
    var body: some View {
        Image(uiImage: UIImage(systemName: image)!)
             .resizable()
             .scaledToFit()
            .onTapGesture {
                self.isActive = true
            }
        .background(
             NavigationLink (
                  destination: ImageDetail(image: image), isActive: $isActive,
                  label: {
                    EmptyView()
                  }
             ))
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 这是一个解决方案,但似乎苹果将来应该修复这个问题,对吧? (2认同)