3 текстовых поля, 1 вид выбора, но при использовании pickerView выбор не отображается в текстовом поле

UIPickerView показывает данные, но не передает в UITextField.

Я проверил другой пост, чтобы сравнить свой код, но все еще не могу найти решение. ваша помощь очень ценится.

import UIKit

class ViewController: UIViewController, UIPickerViewDataSource, UIPickerViewDelegate, UITextFieldDelegate {

    @IBOutlet weak var hospNameField: UITextField!
    @IBOutlet weak var teamNameField: UITextField!
    @IBOutlet weak var mdNameField: UITextField!
    @IBOutlet weak var selectionsPickerView: UIPickerView!

    var hosp = ["hosp1", "hosp2", "hosp3"]
    var team = ["team1", "team2", "team3"]
    var mds = ["MD1", "MD2", "MD3"]

    var itemSelected = ""
    var textFieldSelected = UITextField()

    weak var pickerView: UIPickerView?

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.

        let pickerView = UIPickerView()
        pickerView.delegate = self
        pickerView.dataSource = self

        hospNameField.inputView = pickerView
        teamNameField.inputView = pickerView
        mdNameField.inputView = pickerView

        hospNameField.delegate = self
        teamNameField.delegate = self
        mdNameField.delegate = self

        self.pickerView = pickerView
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func numberOfComponents(in pickerView: UIPickerView) -> Int {
        return 1
    }

    func textFieldDidBeginEditing(_ textField: UITextField) {
        textFieldSelected = textField
    }

    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        if hospNameField.isFirstResponder {
            return hosp.count
        } else if teamNameField.isFirstResponder {
            return team.count
        } else if mdNameField.isFirstResponder {
            return mds.count
        }
        return 0
    }

    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        if hospNameField.isFirstResponder {
            return hosp[row]
        } else if teamNameField.isFirstResponder {
            return team[row]
        } else if mdNameField.isFirstResponder {
            return mds[row]
        }
        return nil
    }

    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        if teamNameField.isFirstResponder {
            let itemselected = hosp[row]
            hospNameField.text = itemselected
        } else if teamNameField.isFirstResponder {
            let itemselected = team[row]
            teamNameField.text = itemselected
        } else if mdNameField.isFirstResponder {
            let itemselected = mds[row]
            mdNameField.text = itemselected
        }
    }
}

Я думаю, что weak var pickerView: UIPickerView? не должна быть слабой переменной, оставьте ее var pickerView: UIPickerView?. И нет никакой пользы от selectionsPickerView и textFieldSelected, поэтому удалите их.

Ankit Jayaswal 09.04.2019 08:03
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
1
81
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Я думаю, что ваш код неверен в didSelectRow. проверьте первый и второй if, оба работают в одном и том же состоянии.

if teamNameField.isFirstResponder {
   let itemselected = hosp[row]
   hospNameField.text = itemselected
} else if teamNameField.isFirstResponder {
   let itemselected = team[row]
   teamNameField.text = itemselected
} else if mdNameField.isFirstResponder {
   let itemselected = mds[row]
   mdNameField.text = itemselected
}

Я думаю, вам следует изменить первое if на if hospNameField.isFirstResponder {..}

Ответ принят как подходящий

You have forgotten to subscribe the delegate and data sources to the PickerView..

import UIKit

class ViewController: UIViewController, UIPickerViewDataSource, UIPickerViewDelegate, UITextFieldDelegate {

    @IBOutlet weak var hospNameField: UITextField!
    @IBOutlet weak var teamNameField: UITextField!
    @IBOutlet weak var mdNameField: UITextField!
    @IBOutlet weak var selectionsPickerView: UIPickerView!

    var hosp = ["hosp1", "hosp2", "hosp3"]
    var team = ["team1", "team2", "team3"]
    var mds = ["MD1", "MD2", "MD3"]

    var itemSelected = ""
    var textFieldSelected = UITextField()

    weak var pickerView: UIPickerView?

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.

        let pickerView = UIPickerView()
        pickerView.delegate = self
        pickerView.dataSource = self

        hospNameField.inputView = pickerView
        teamNameField.inputView = pickerView
        mdNameField.inputView = pickerView

        hospNameField.delegate = self
        teamNameField.delegate = self
        mdNameField.delegate = self

        self.pickerView = pickerView
        /**
         the below lines are mandatory for

         pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int)

         to execute
         */
        self.pickerView?.delegate = self
        self.pickerView?.dataSource = self
    }

    func numberOfComponents(in pickerView: UIPickerView) -> Int {
        return 1
    }

    func textFieldDidBeginEditing(_ textField: UITextField) {
        textFieldSelected = textField
    }
    // add this delegate and reload here
  func textFieldShouldBeginEditing(_ textField: UITextField) ->
        Bool {
            self.pickerView?.reloadAllComponents()
            return true
    }

    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        if hospNameField.isFirstResponder {
            return hosp.count
        } else if teamNameField.isFirstResponder {
            return team.count
        } else if mdNameField.isFirstResponder {
            return mds.count
        }
        return 0
    }

    func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        if hospNameField.isFirstResponder {
            return hosp[row]
        } else if teamNameField.isFirstResponder {
            return team[row]
        } else if mdNameField.isFirstResponder {
            return mds[row]
        }
        return nil
    }

    func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        /**
         type here, need to check the responder for hospNameField also
         you have executed teamNameField.isFirstResponder twice
         */
        if hospNameField.isFirstResponder {
            let itemselected = hosp[row]
            hospNameField.text = itemselected
        } else if teamNameField.isFirstResponder {
            let itemselected = team[row]
            teamNameField.text = itemselected
        } else if mdNameField.isFirstResponder {
            let itemselected = mds[row]
            mdNameField.text = itemselected
        }
    }
}

круто, я смог решить проблему. Я устал и не заметил dup.lol..еще одна вещь, когда я переключаюсь, скажем, с hosp UITextField на команду UITextField, pickerView не обновляется и показывает параметры прыжков, но я все еще могу выбрать другая команда (надеюсь, я объясняюсь). в pickerView мне нужно несколько раз прокрутить вверх и вниз, чтобы показать другую переменную. Спасибо всем за вашу помощь!

Eddie 09.04.2019 16:21

Вы можете перезагрузить компоненты представления Picker, чтобы это заработало. Это можно сделать в делегате сделалНачало редактирования текстового поля. Проверьте мой отредактированный ответ.

Saurabh Yadav 10.04.2019 06:44

Другие вопросы по теме