Как передать выбранное значение строки в качестве публичной переменной, доступной для нескольких контроллеров представления? - PullRequest
0 голосов
/ 27 июня 2019

Как передать значение выбранного tableView в публичную переменную, к которой могут обращаться несколько ViewControllers? В настоящее время в didSelectRowAt я определяю выбранную строку как portfolio, делая let portfolio = structure[indexPath.row] Теперь, как я могу сохранить это значение, возможно, в какую-то переменную, которая делает его доступным для контроллера нескольких представлений?

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

В прошлом я пытался использовать userdefaults, но это не подходит для значений, которые постоянно меняются и не являются постоянными.

import UIKit

class ScheduledCell: UITableViewCell {

    @IBOutlet weak var ETALabel: UILabel!
    @IBOutlet weak var cellStructure: UIView!

    @IBOutlet weak var scheduledLabel: UILabel!
    @IBOutlet weak var testingCell: UILabel!
    @IBOutlet weak var pickupLabel: UILabel!
    @IBOutlet weak var deliveryLabel: UILabel!
    @IBOutlet weak var stopLabel: UILabel!
    @IBOutlet weak var topBar: UIView!


}

class ToCustomerTableViewController: UITableViewController, UIGestureRecognizerDelegate {

    var typeValue = String()

    var driverName = UserDefaults.standard.string(forKey: "name")!
    var structure = [AlreadyScheduledStructure]()


    override func viewDidLoad() {
        super.viewDidLoad()

        fetchJSON()


        //Disable delay in button tap
        self.tableView.delaysContentTouches = false

        tableView.tableFooterView = UIView()

    }


    private func fetchJSON() {
        guard let url = URL(string: "https://example.com/example/example"),
            let value = driverName.addingPercentEncoding(withAllowedCharacters: .urlQueryValueAllowed)
            else { return }

        var request = URLRequest(url: url)
        request.httpMethod = "POST"
        request.httpBody = "driverName=\(value)".data(using: .utf8)

        URLSession.shared.dataTask(with: request) { data, _, error in
            guard let data = data else { return }


            do {
                self.structure = try JSONDecoder().decode([AlreadyScheduledStructure].self,from:data)
                DispatchQueue.main.async {
                    self.tableView.reloadData()
                }
            }
            catch {
                print(error)
            }

            }.resume()

    }



    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return structure.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "scheduledID", for: indexPath) as! ScheduledCell
        let portfolio = structure[indexPath.row]
        cell.stopLabel.text = "Stop \(portfolio.stop_sequence)"
        cell.testingCell.text = portfolio.customer
        return cell

    }

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {


        let portfolio = structure[indexPath.row]
        let controller = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "scheduledDelivery")

        print(portfolio.customer)
        controller.navigationItem.title = navTitle
        navigationController?.pushViewController(controller, animated: true)
    }


    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 200.0
    }

}

Ответы [ 2 ]

0 голосов
/ 27 июня 2019

Вы можете использовать NSNotificationCenter и отправлять значение после выбора, и каждый подписанный контроллер получит новое значение.Для получения дополнительной информации читайте это NSNotificationCenter addObserver в Swift

0 голосов
/ 27 июня 2019

Вы можете использовать функцию для передачи необязательного значения внутри extension, попробуйте следующее:

Из того, что я понял, вы хотите передать значения из вашего viewController и иметь возможность получить его из любого другого viewController ..

extension UIViewController { 

  func passData(row: Int?) -> Int? {

    var myValue = Int()

    if row != nil {
        myValue = row!
    }

    return myValue
}

   } 

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

passData(row: indexPath.row)

и если вы хотите получить его значение из другого viewController, используйте это:

let myValue = passData(row: nil)

таким образом, вы можете получить данные, которые вы передаете от другого viewController .. если это не сработало для вас, я бы предложил вам использовать UserDefaults ..

Надеюсь, это решит вашу проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...