带有两个选项卡的简单SwiftUI TabView,每个选项卡上都使用一个简单的Picker视图。 应用启动时,选择器可见,并更新变量。 选择第二个选项卡,然后选择器消失。
let names = ["Fred", "Wilma", "Betty", "Barney"]
struct WordPickerView: View {
@State var kind: Int = 0
var body: some View {
VStack {
Text(names[kind])
Picker(selection: $kind, label: EmptyView()) {
ForEach(0 ..< names.count) {index in
Text(names[index]).tag(index)
}
}.pickerStyle(SegmentedPickerStyle())
}
}
}
struct ContentView: View {
@State private var selection = 0
var body: some View {
TabView(selection: $selection){
WordPickerView()
.font(.title)
.tabItem {
VStack {
Image("first")
Text("First")
}
}
.tag(0)
WordPickerView()
.font(.title)
.tabItem {
VStack {
Image("second")
Text("Second")
}
}
.tag(1)
}
}
}
答案 0 :(得分:0)
在这种情况下(当您拥有绝对相等的视图时),最好使用.id
使它们唯一。
因此,您的情况可以通过以下方式解决
Picker(selection: $kind, label: EmptyView()) {
ForEach(0 ..< names.count) {index in
Text(names[index]).tag(index)
}
}
.pickerStyle(SegmentedPickerStyle())
.id(UUID().uuidString)