繁体   English   中英

SwiftUI List() 不显示 macOS 上的孩子

[英]SwiftUI List() doesn't show .children on macOS

更新

我正在尝试在SwiftUIList( tree, children:) )中使用分层List视图。 我发现如果第一个列表元素没有子元素,则只显示层次结构的顶层。 对我来说,这看起来像是 SwiftUI 中的一个错误。 我想知道是否有人知道一个好的解决方法。

[这是我的问题的更好版本,使用相同的struct类型和相同的数组元素]

@main
struct bug_reportApp: App {
    var body: some Scene {
        WindowGroup {
            ContentView()
        }
    }
}


struct FileItem: Hashable, Identifiable, CustomStringConvertible {
    var id: Self { self }
    var name: String
    var children: [FileItem]? = nil
    var description: String {
        return name
    }
}


let tree0: [FileItem] = [
  FileItem(name: "users", children:
    [FileItem(name: "user1234", children:
      [FileItem(name: "Photos", children:
        [FileItem(name: "photo001.jpg"),
         FileItem(name: "photo002.jpg")]),
       FileItem(name: "Movies", children:
         [FileItem(name: "movie001.mp4")]),
          FileItem(name: "Documents")
      ]),
     FileItem(name: "newuser", children:
       [FileItem(name: "Documents", children: [])
       ])
    ]),
    FileItem(name: "private", children: nil)
]

let tree1 = [tree0[1], tree0[0]]
let tree2 = [FileItem(name: "private", children: []), tree0[0]]


struct ContentView: View {

    

    var body: some View {
        HStack{
            VStack{
                Text("Works").font(.headline)
                List(tree0, children: \.children) { item in
                    Text(item.description)
                }
            }
            
            VStack{
                Text("First element has empty .children").font(.headline)
                List(tree2, children: \.children) { item in
                    Text(item.description)
                }
            }
        
            VStack{
                Text("First element has nil .children").font(.headline)
                List(tree1, children: \.children) { item in
                    Text(item.description)
                }
            }
          
        }
    }
}

这是一个带注释的屏幕截图,突出显示丢失的树扩展箭头在/应该在哪里。 截屏

原始问题

我正在尝试在SwiftUIList( tree, children:) )中使用分层List视图。

我不明白为什么我在这里的简单示例仅显示 3 个顶级 3 项,没有小箭头来展开列表元素 #2 下的子列表。

我可以剪切和粘贴看起来非常相似的示例(到同一个项目、同一个文件中),它们确实有效……但我看不出区别!

我的代码不起作用:


import SwiftUI

struct TreeIndexNode: Hashable, Identifiable, CustomStringConvertible {
    var id: Int
    var children: [TreeIndexNode]? = nil
    var description: String {
        return String("\(id)")
    }
}

struct ContentView: View {
    
    let tree: [TreeIndexNode] = [ TreeIndexNode(id: 1), TreeIndexNode(id: 2, children: [
        TreeIndexNode(id: 3),
        TreeIndexNode(id: 4),
    ]),
    TreeIndexNode(id: 8),
    ]
    
    var body: some View {
        List( tree, children: \.children) { row in
            Text(row.description)
        }
    }
}

但是如果我从 Apple Developer 页面将其切换到此示例,它会按预期工作:


struct ContentView: View {
    struct FileItem: Hashable, Identifiable, CustomStringConvertible {
        var id: Self { self }
        var name: String
        var children: [FileItem]? = nil
        var description: String {
            switch children {
            case nil:
                return "📄 \(name)"
            case .some(let children):
                return children.isEmpty ? "📂 \(name)" : "📁 \(name)"
            }
        }
    }
    let fileHierarchyData: [FileItem] = [
      FileItem(name: "users", children:
        [FileItem(name: "user1234", children:
          [FileItem(name: "Photos", children:
            [FileItem(name: "photo001.jpg"),
             FileItem(name: "photo002.jpg")]),
           FileItem(name: "Movies", children:
             [FileItem(name: "movie001.mp4")]),
              FileItem(name: "Documents", children: [])
          ]),
         FileItem(name: "newuser", children:
           [FileItem(name: "Documents", children: [])
           ])
        ]),
        FileItem(name: "private", children: nil)
    ]
    var body: some View {
        List(fileHierarchyData, children: \.children) { item in
            Text(item.description)
        }
    }
}

我从 Xcode 12.4“多平台”项目模板开始。 这是它在 MacOS 上的样子:

上面我的代码的非工作 MacOS 构建的屏幕截图

当我为 iOS 构建时,它确实按预期工作:

我在 iOS 模拟器中的代码

您的代码在 MacOS 上按预期工作。 所有三个列表都显示了正确的可扩展子项。

在此处输入图像描述

您可以尝试重新启动/更新 XCode。 一个奇怪的地方是,箭头在上面的截图中出现在右边,而在帖子中它们出现在左边。 您是否在项目中添加了某些语言/区域设置/格式设置但未包含在上面的代码段中?

顺便说一句,所编写的代码已将标签交换为儿童 nil 与空儿童。 澄清一下, tree1的子节点nil ,而tree2的子节点为空。 上面的截图运行了 OP 的原始未修改代码。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM