foreach - SwiftUI - 尝试识别并传递被选中的列表项的值
问题描述
我正在关注与 UIKIt 交互的 Apple Developer 教程
唯一真正的区别是我试图打电话给
PageView<Page:View> {
来自 NavigationLink。PageView 中的示例代码具有硬编码的默认值
@State var currentPage = 0
我宁愿在用户选择的视图上启动滑动过程,而不是从第一个开始,我正在尝试创建一种简单的方法来滑动项目,而无需返回导航链接以访问下一个项目名单。
有没有办法捕获用户选择的链接的索引并将其作为变量传递给 PageView。
我尝试增加一个计数器并使用一个函数来增加计数器并返回 PageView sruct 没有任何成功。Animals 是一个数组,以防万一不清楚,我正在使用 map 函数传入适当的值来创建我要创建的详细视图。另外,我意识到我可以将详细视图放在滚动视图中。
这是我的代码
var body: some View {
List {
ForEach(collection.animals, id: \.self) { animal in
NavigationLink(destination:PageView(self.collection.animals.map { AnimalDetail(animalMetadata: $0.wrappedMetadata )})) {
AnimalRow(thumbnailImage: Image(uiImage: UIImage(data: animal.image!)!), label: (animal.name!) ).font(.subheadline)
}
}.onDelete(perform: delete)
}
其他一切似乎工作正常 - 只是无法找到一种方法来从列表中捕获索引值以指示单击了哪个项目/视图并将该值传递给 PageView 以便将其创建为第一个查看的视图。
谢谢 !
编辑
我尝试在 Array 上使用 .enumerated() ,但仍然无法弄清楚如何将特定索引值获取到 PAgeView 视图。
List {
ForEach(Array(collection.animals.enumerated()), id: \.1.id) {index, item in
NavigationLink(destination:PageView( self.collection.animals.map { AnimalDetail(animalMetadata: $0.wrappedMetadata)} )) {
AnimalRow(thumbnailImage: Image(uiImage: UIImage(data: item.image!)!), label: (animal.name!) ).font(.subheadline)
}
}.onDelete(perform: delete)
解决方案
尝试以下...
在PageView
:
struct PageView<Page: View>: View {
var viewControllers: [UIHostingController<Page>]
@State var currentPage: Int // no initial value
init(_ views: [Page], selection: Int) {
_currentPage = State(initialValue: selection)
self.viewControllers = views.map { UIHostingController(rootView: $0) }
}
// ... other code here
}
在您的代码中:
var body: some View {
List {
ForEach(Array(collection.animals.enumerated()), id: \.element) { idx, animal in
NavigationLink(destination:
PageView(self.collection.animals.map {
AnimalDetail(animalMetadata: $0.wrappedMetadata )},
selection: idx)) { // << here !!
AnimalRowRow(thumbnailImage: Image(uiImage: UIImage(data: animal.image!)!),
label: (animal.name!) ).font(.subheadline)
}
}.onDelete(perform: delete)
}
推荐阅读
- python - 如何优化推理脚本以获得更快的分类器预测?
- javascript - 没有找到目标 DOM 元素?
- asp.net - 在每个回发页面上都会在新选项卡中打开
- php - TableEdit 插件 - 同一页面上的两个表 - TableEdit 插件仅在两个表都有数据时工作
- elasticsearch - 字段相等的 Kibana 过滤器返回两个具有不同字段值的文档
- python - 删除列表中的空格字符
- javascript - document.addEventListender 测试无法使用 Jest 和 Enzyme
- powershell - 在 Jenkins 构建的 Windows Powershell 中设置的变量,在其他构建步骤中不可用
- oracle - 需要更新 oracle register xml schema 中的一个属性
- angularjs - 范围变量如何使用 angularjs 在 jasmine 框架中访问