PickerView 被禁用并且在 SwiftUI 中不起作用

Posted

技术标签:

【中文标题】PickerView 被禁用并且在 SwiftUI 中不起作用【英文标题】:PickerView disabled and doesn't work in SwiftUI 【发布时间】:2020-10-14 11:34:18 【问题描述】:

我不明白为什么选择器视图不起作用。我使用了这段代码:

导入 SwiftUI

struct NewChecklistItemView: View 

    var colors = ["Red", "Green", "Blue", "Tartan"]
    @State private var selectedColor = 0


  var checklist: Checklist
  @State var newItemName: String = ""
  @Environment(\.presentationMode) var presentationMode

  var body: some View 
    VStack 
      Text("Add new item")
      Form 
        TextField("Enter new item name here", text: $newItemName)
        Picker(selection: $selectedColor, label: Text("Please choose a color")) 
           ForEach(0 ..< colors.count)  
              Text(self.colors[$0])
           
        
        Text("You selected: \(colors[selectedColor])")

        Button(action: 
        //let newChecklistItem = Category(title: "Category", items: [ChecklistItem(name: self.newItemName)])
            let newItem = ChecklistItem(name: self.newItemName)

            self.checklist.items[0].items.append(newItem)
          self.checklist.printChecklistContents()
          self.presentationMode.wrappedValue.dismiss()
        ) 
          HStack 
            Image(systemName: "plus.circle.fill")
            Text("Add new item")
          
        
        .disabled(newItemName.count == 0)

      
      Text("Swipe down to cancel.")
    
  


struct NewChecklistItemView_Previews: PreviewProvider 
  static var previews: some View 
    NewChecklistItemView(checklist: Checklist())
  

PickerView 为灰色且已禁用。所以我不能选择价值观。可能是什么问题呢?我试图移动pickerView,但没有帮助。

【问题讨论】:

【参考方案1】:

要使PickerForm 中工作,您必须将其嵌入到NavigationView 中,例如

NavigationView 
  Text("Add new item")
  Form 
    TextField("Enter new item name here", text: $newItemName)
    Picker(selection: $selectedColor, label: Text("Please choose a color")) 

(当然,这可能需要重新设计/重新布局)...或使用不同的样式选择器样式。

【讨论】:

以上是关于PickerView 被禁用并且在 SwiftUI 中不起作用的主要内容,如果未能解决你的问题,请参考以下文章

SwiftUI |从另一个 SwiftUI 视图访问 PickerView 选择

检查pickerView SwiftUi中的选择

SwiftUI-使用drawingGroup()禁用TextField

SwiftUI PickerView 与工作回调如何?

SwiftUI - TextField 在 macOS 上的 List 中被禁用(不可编辑)

如何在 SwiftUI 中禁用位置动画?