Создание textField новой ячейки UITableView как firstResponder

В настоящее время у меня есть табличное представление с ячейками, содержащими метку и textfield, у меня также есть элемент кнопки + bar, который добавляет новые ячейки.

Я надеюсь, что когда пользователь нажимает кнопку +, создается новая ячейка, и текстовое поле этой ячейки автоматически становится первым респондентом.

Ниже приведен мой текущий код для создания новой записи:

    func newNoteline() {
    let entityDescription = NSEntityDescription.entity(forEntityName: "NotebookContentEntity", in: context)

    let item = NotebookContentEntity(entity: entityDescription!, insertInto: context)

    item.notebookEntry = ""
    item.timeOfEntry = timeOutlet.text

    do {

        try context.save()
    } catch {
        print(error)
        return
    }
    loadNotelines()
    }

Я придумал несколько способов решить эту проблему, но мне не удалось заставить их работать, включая использование .tag в текстовом поле сразу после его создания - с помощью делегата текстового поля или с помощью метода делегата tableView - indexPathForPreferredFocusedView.

Я просто не могу понять, как заставить сфокусироваться на определенном текстовом поле в ячейке без того, чтобы пользователь коснулся текстового поля. Есть предположения?


person David    schedule 26.02.2019    source источник
comment
вы можете вызвать статьFirstResponder текстового поля   -  person Jarvis The Avenger    schedule 26.02.2019


Ответы (1)


вызов метода textField. beginFirstResponder () должен делать то, что вы ищете. Когда вызывать эту функцию, решать вам. например, для в приведенном ниже коде в cellForRowAt я проверил, является ли значение пустым, а затем сделайте текущее текстовое поле первым ответчиком.

   class Test: UIViewController{

        var myView: TestView{return view as! TestView}
        unowned var tableView: UITableView {return myView.tableView}
        unowned var button: UIButton {return myView.button}

        var list = [String]()

        override func loadView() {
            view = TestView()
        }

        override func viewDidLoad() {
            super.viewDidLoad()
            for i in 1...10{
                list.append("Test \(i)")
            }
            tableView.dataSource = self
            button.addTarget(self, action: #selector(didSelect(_:)), for: .touchUpInside)
        }

        @objc func didSelect(_ sender: UIButton){
            let indexPath = IndexPath(row: list.count, section: 0)
            list.append("")
            tableView.insertRows(at: [indexPath], with: .automatic)
            tableView.scrollToRow(at: indexPath, at: .bottom, animated: true)
        }
    }
    extension Test: UITableViewDataSource{
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return list.count
        }

        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let cell = tableView.dequeueReusableCell(withIdentifier: "TestViewCell", for: indexPath) as! TestViewCell
            let value = list[indexPath.row]
            cell.textField.text = value
            if value.isEmpty{
                cell.textField.becomeFirstResponder()
            }
            return cell
        }
    }
person Sahil Manchanda    schedule 26.02.2019