почему не работает этот код для передачи данных между контроллерами? - PullRequest
0 голосов
/ 03 сентября 2018

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

контроллер основного вида

class mainController: UIViewController, sendDataDelegate {

    let label: UILabel = {
        let lab = UILabel()
        lab.text = "No data"
        lab.textAlignment = .center
        lab.translatesAutoresizingMaskIntoConstraints = false
        return lab
    }()

    let tapRecognizer = UITapGestureRecognizer()
    let secondVC = SecondViewController()


    override func viewDidLoad() {
        super.viewDidLoad()
        view.backgroundColor = UIColor.green


        //  assign delegate to self, not working...
        secondVC.delegate = self


        tapRecognizer.addTarget(self, action: #selector(goToSecondVC))
        view.addGestureRecognizer(tapRecognizer)
        view.addSubview(label)

        // label constraints..
        view.addConstraints(NSLayoutConstraint.constraints(withVisualFormat: "H:|[v0]|", options: NSLayoutFormatOptions(), metrics: nil, views: ["v0":label]))
        view.addConstraints(NSLayoutConstraint.constraints(withVisualFormat: "V:|-200-[v0]", options: NSLayoutFormatOptions(), metrics: nil, views: ["v0":label]))
    }

    @objc func goToSecondVC(){
           show(SecondViewController(), sender: nil)
    }

    func passData(str: String) {
        print(str)
        label.text = str

    }

}

и второй контроллер представления плюс протокол для отправки данных ...

import UIKit


//protocol to pass the data..

protocol sendDataDelegate {
    func passData(str: String)
}



class SecondViewController: UIViewController {

    let tapRecog = UITapGestureRecognizer()

    let dataStr = "data passed"


    var delegate: sendDataDelegate?



    override func viewDidLoad() {
        super.viewDidLoad()

        view.backgroundColor = UIColor.red
        tapRecog.addTarget(self, action: #selector(goBack))
        view.addGestureRecognizer(tapRecog)

    }

    @objc func goBack(){

//        trying to pass data here..
        delegate?.passData(str: dataStr)

//        dismiss view...
        dismiss(animated: true, completion: nil)

    }

}

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

Заранее всем спасибо за ответы! хорошего дня)

Ответы [ 3 ]

0 голосов
/ 03 сентября 2018

изменить goToSecondVC() метод, как показано ниже:

 @objc func goToSecondVC(){
        let vc = SecondViewController()
        vc.delegate = self
        show(vc, sender: nil)
 }
0 голосов
/ 03 сентября 2018

Это исправление решит вашу проблему:

@objc func goToSecondVC(){
    show(secondVC, sender: nil)
}

Протоколы лучше называть заглавными буквами:

 protocol SendDataDelegate: AnyObject {
     func passData(str: String)
 }

И не забывайте о слабом делегате:

weak var delegate: SendDataDelegate?
0 голосов
/ 03 сентября 2018

В вашей функции goToSecondVC вы создаете совершенно новый контроллер представления и игнорируете созданное вами свойство.

Измените его на secondVC вместо SecondViewController().

...