微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何删除可扩展列表swiftUI中的行?

如何解决如何删除可扩展列表swiftUI中的行?

我尝试在 swiftUI 的可扩展列表中通过 onDelete(perform:) 修饰符删除行并嵌入 EditButton() 因此用户可以更改列表中项目的顺序。下面是应用程序的图像:>

enter image description here

这是我的代码(查看):

import SwiftUI

struct ContentView: View {
    var body: some View {
        NavigationView {
            vstack {
                List(sampleMenuItems,children: \.subMenuItems) { item in
                    HStack {
                    
                    Text(item.name)
                        .font(.system(.title3,design: .rounded))
                        .bold()
                }
            }
        }
        .listStyle(InsetGroupedListStyle())
        .navigationTitle("List")
        .navigationBarItems(trailing:
                                Button(action: {}) {
                                    EditButton()
                                }
        )
    }
}
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

和数据模型:

import Foundation

struct MenuItem: Identifiable,Hashable {
    var id = UUID()
    var name: String
    var subMenuItems: [MenuItem]?
}

let sampleMenuItems = [ MenuItem(name: "iphone model",subMenuItems: iphoneModelItems),MenuItem(name: "ipad model",subMenuItems: ipadModelItems),]

// Sub-menu items for iphone
let iphoneModelItems = [ MenuItem(name: "pro max"),MenuItem(name: "pro"),MenuItem(name: "se")
                                ]
 
// Sub-menu items for ipad
let ipadModelItems = [ MenuItem(name: "pro"),MenuItem(name: "air"),]

我知道如果我想使用 onDelete(perform:) 我应该将我的数据放入 ForEach 所以我这样做了这是我的问题我不知道如何解决children: \.subMenuItems部分:

List {
                    ForEach(sampleMenuItems,children: \.subMenuItems) { item in
                        HStack {
                        
                        Text(item.name)
                            .font(.system(.title3,design: .rounded))
                            .bold()
                    }
                }
            }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。