SwiftUI Picker视图在TabView中消失

时间:2019-12-22 04:06:04

标签: swiftui picker tabview

带有两个选项卡的简单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)
        }
    }
}

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)