多个文本字段输入视图的多个选择器视图很快

前端之家收集整理的这篇文章主要介绍了多个文本字段输入视图的多个选择器视图很快前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在搜索论坛,没有任何帮助.
我在一个视图控制器中使用4个文本字段,对于每个文本字段,我使用单独的pickerView作为textFields(4pickers)的inputViews.

当我单击第一个textField时,pickerView1成功显示,文本字段显示数据,但是当我单击第二,第三和第四个文本字段时,会出现第一个pickerView.
我怀疑错误在于inputView声明.

如果你能帮助为pickerView添加一个“完成”按钮,我将非常感激.

我的代码

  1. class ViewController1: UIViewController,UIPickerViewDelegate
  2. {
  3.  
  4. @IBOutlet var pickerView1: UIPickerView!
  5. @IBOutlet var pickerView2: UIPickerView!
  6. @IBOutlet var pickerView3: UIPickerView!
  7. @IBOutlet var pickerView4: UIPickerView!
  8.  
  9. @IBOutlet var textField1: UITextField!
  10. @IBOutlet var textField2: UITextField!
  11. @IBOutlet var textField3: UITextField!
  12. @IBOutlet var textField4: UITextField!
  13.  
  14. var hazards = ["a","b","c"]
  15. var reasons = ["d","e","f"]
  16. var site = ["v","h","i","j"]
  17. var line = ["k","l","m","n"]
  18.  
  19. override func viewDidLoad() {
  20.  
  21. super.viewDidLoad()
  22. pickerView1 = UIPickerView()
  23. pickerView2 = UIPickerView()
  24. pickerView3 = UIPickerView()
  25. pickerView4 = UIPickerView()
  26. pickerView1.delegate = self
  27. pickerView2.delegate = self
  28. pickerView3.delegate = self
  29. pickerView4.delegate = self
  30.  
  31. self.textField1.inputView = self.pickerView1;
  32. self.textField2.inputView = self.pickerView2;
  33. self.textField3.inputView = self.pickerView3;
  34. self.textField4.inputView = self.pickerView4;
  35. }
  36.  
  37. func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
  38. return 1
  39. }
  40.  
  41. func pickerView(pickerView: UIPickerView,numberOfRowsInComponent component: Int) -> Int {
  42.  
  43. if pickerView.tag == 0 {
  44. return hazards.count
  45. } else if pickerView.tag == 1 {
  46. return reasons.count
  47. } else if pickerView.tag == 2 {
  48. return site.count
  49. } else if pickerView.tag == 3 {
  50. return line.count
  51. }
  52. return 1
  53. }
  54.  
  55. func pickerView(pickerView: UIPickerView,titleForRow row: Int,forComponent component: Int) -> String! {
  56.  
  57. if pickerView.tag == 0 {
  58. return hazards[row]
  59. } else if pickerView.tag == 1 {
  60. return reasons[row]
  61. } else if pickerView.tag == 2 {
  62. return site[row]
  63. } else if pickerView.tag == 3 {
  64. return line[row]
  65. }
  66.  
  67. return ""
  68. }
  69.  
  70. func pickerView(pickerView: UIPickerView,didSelectRow row: Int,inComponent component: Int) {
  71.  
  72. if pickerView.tag == 0 {
  73. textField1.text = hazards[row]
  74. } else if pickerView.tag == 1 {
  75. textField2.text = reasons[row]
  76. } else if pickerView.tag == 2 {
  77. textField3.text = site[row]
  78. } else if pickerView.tag == 3 {
  79. textField4.text = line[row]
  80. }
  81. }
  82. }
您正在使用选择器视图的标记属性来确定哪个数组是给定选取器视图的数据源,但您最初没有设置标记.标签默认为零,因此所有四个选择器视图都显示相同的数据.在实例化您的选择器视图后,添加以下内容
  1. pickerView1.tag = 0
  2. pickerView2.tag = 1
  3. pickerView3.tag = 2
  4. pickerView4.tag = 3

猜你在找的Swift相关文章