在 SwiftUI 中使用 List 时如何使用 NavigationLink isActive 绑定?
How does one use NavigationLink isActive binding when working with List in SwiftUI?
用例非常简单。我有一个地点列表,每个地点对应一个地理围栏。我需要在用户所在的地理围栏所在的特定行中启用导航。该列表是动态的,是从 API 中获取的。 Whosebug 上也有类似的问题,但那些只针对静态列表。
我试过使用布尔字典,但我无法让它工作。
这是一个简化的模拟代码:
struct ListView: View {
@State private var navActive: [UUID: Bool] = [:]
var body: some View {
List (viewModel.allItems, id: \.id) { item in
NavigationLink(destination: DetailView(item), isActive: $navActive[item.id]) {
Text(item.name)
.onTapGesture {
if currentLocation.isInside(item.geofence) { navActive[item.id] = true }
}
}
}
}
}
我收到此错误:无法将类型 'Binding<Bool?>' 的值转换为预期的参数类型 'Binding<Bool>'
在 NavigationLink isActive 参数上。
注意:我在使用 onRecieve 修饰符接收 allItems 时用键值对填充了 navActive 字典
这是您的用例的可能方法
struct ListView: View {
// ... your view model defined here
@State private var selectedItem: UUID? = nil
var body: some View {
List (viewModel.allItems, id: \.id) { item in
Text(item.name)
.onTapGesture {
self.selectedItem = item.id
}
.background(
NavigationLink(destination: DetailView(item), tag: item.id,
selection: $selectedItem) { EmptyView() }
.buttonStyle(PlainButtonStyle())
)
}
}
}
用例非常简单。我有一个地点列表,每个地点对应一个地理围栏。我需要在用户所在的地理围栏所在的特定行中启用导航。该列表是动态的,是从 API 中获取的。 Whosebug 上也有类似的问题,但那些只针对静态列表。
我试过使用布尔字典,但我无法让它工作。
这是一个简化的模拟代码:
struct ListView: View {
@State private var navActive: [UUID: Bool] = [:]
var body: some View {
List (viewModel.allItems, id: \.id) { item in
NavigationLink(destination: DetailView(item), isActive: $navActive[item.id]) {
Text(item.name)
.onTapGesture {
if currentLocation.isInside(item.geofence) { navActive[item.id] = true }
}
}
}
}
}
我收到此错误:无法将类型 'Binding<Bool?>' 的值转换为预期的参数类型 'Binding<Bool>' 在 NavigationLink isActive 参数上。
注意:我在使用 onRecieve 修饰符接收 allItems 时用键值对填充了 navActive 字典
这是您的用例的可能方法
struct ListView: View {
// ... your view model defined here
@State private var selectedItem: UUID? = nil
var body: some View {
List (viewModel.allItems, id: \.id) { item in
Text(item.name)
.onTapGesture {
self.selectedItem = item.id
}
.background(
NavigationLink(destination: DetailView(item), tag: item.id,
selection: $selectedItem) { EmptyView() }
.buttonStyle(PlainButtonStyle())
)
}
}
}