关闭 ViewController 并重新加载上一个/传回数据?

问题描述 投票:0回答:3

我的应用程序从服务器下载更新。为此,它将设备上的数据与服务器上的可用数据进行比较。如果不匹配,布尔值“updateAvailable”将设置为 true,并向用户显示交互式 UILabel,指示他们可以下载更新。

(稍微简化的代码)

class ViewController: UIViewController {

@IBOutlet weak var updateLabel: UILabel!

func updateChecker(){
    let deviceVersion = self.settingsController.getDeviceVersion()

    //Get Server Version (Async)
    _ = settingsController.getServerVersion() { (data) -> () in

        dispatch_async(dispatch_get_main_queue()){

            if deviceVersion != data{
                self.updateAvailable = true
            }
            else{
                self.updateAvailable = false
            }

            //Update UI
            self.updateUI()    
         }
    }
}

func updateUI(){
    if updateAvailable{
        updateLabel.text = "Update Available"
    }
    else{
        updateLabel.text = "App Up To Date"
    }
}


触摸此更新标签时,应用程序会触发到“updateViewController”的自定义 Segue:

 @IBAction func getUpdateLabelPressed(sender: UITapGestureRecognizer) {
    if updateAvailable{
        self.performSegueWithIdentifier("segueToUpdateView", sender: self)
    }



UpdateViewController 从服务器下载数据(异步),然后被关闭:

class UpdateViewController: UIViewController{
override func viewDidLoad() {
    super.viewDidLoad()        

    //Create Settings Controller + Get Update        
    let sc = SettingsController()
    sc.getUpdate({ (success) -> () in

        if success{
            dispatch_async(dispatch_get_main_queue()){    
            print("Update Success")
            self.dismissViewControllerAnimated(true, completion: nil)       
            }
         }
        else{   
            dispatch_async(dispatch_get_main_queue()){    
            print("Update Failed")
            self.dismissViewControllerAnimated(true, completion: nil)
            }
        }
     })       
}


关闭 UpdateViewController 时,会显示主 ViewController,但“updateAvailable”仍设置为 true,并且 updateLabel 仍处于活动状态。

触发另一个自定义 Segue 返回 ViewController / Root ViewController 对我来说不是一种选择,因为这会通过在堆栈中创建多个“ViewController”实例来中断后台更新获取。

onViewDidAppear() 在这种情况下也不合适,因为它会导致网络/服务器流量过大。

如何关闭 UpdateViewController AND 重新加载之前的 ViewController OR 发回触发 ViewController 的 updateChecker() 方法的数据? 或者清除整个ViewControllerStack并重新启动应用程序?

我知道委托安排似乎是合适的,但之前有关此主题的问题和答案(例如this)是针对 Objective-C 的,我无法将这些答案改编为 Swift 2.0。

任何帮助将不胜感激。

swift cocoa-touch uiviewcontroller delegates swift2
3个回答
2
投票

在UpdateViewController中创建一个闭包属性

clearUpdateAvailable

class UpdateViewController: UIViewController {
  var clearUpdateAvailable: (()->())?

  override func viewWillDisappear(animated: Bool) {
    super.viewWillDisappear(animated)
    clearUpdateAvailable?()
  }
}

您可以在viewWillDisappear中或在从服务器接收数据的方法中调用

clearUpdateAvailable

在 ViewController 中,通过 ID 呈现 UpdateViewController 时提供一个闭包。

let storyboard = UIStoryboard(name: "Main", bundle: nil)
if let updateViewController = storyboard.instantiateViewControllerWithIdentifier("updateViewController") as? UpdateViewController {
  updateViewController.clearUpdateAvailable = { [weak self] in
    self?.updateAvailable = false
    self?.updateUI()
  } 
  presentViewController(updateViewController, animated: true, completion: nil)
}

1
投票

将您的主要

ViewController
传递给
UpdateViewController
方法中的
prepareForSegue

完成更新后,更新

updateAvailable
控制器的
ViewController
标志。

这样,在主

ViewController
消失并出现时,ViewController中的updateAvailable将是
YES

请记住设置 updateAvailable 标志和 UpdateViewController 中 ViewController 的引用为 public。到 能够在课堂之外更新这些值。


0
投票

在我的第二个视图控制器上,我正在收集数据并希望将其发送回父控制器。一旦父控制器收到数据,我想触发名为

callGetSearchedJobs()
的函数。 但在第二个视图控制器被关闭后它不会被召回。

override func viewDidDisappear(_ animated: Bool) {

    super.viewDidDisappear(animated)
    if let jobOffeVC = presentedViewController as? JobOffersVC {

        DispatchQueue.main.async {
            jobOffeVC.callGetSearchedJobs()
            jobOffeVC.jobOfferTable.reloadData()
        }
    }
}

第一个视图控制器:

extension JobOffersVC: JobFilltersVCDelegate {

  func sendDatatoJobOffersVC(myData: SearchJobInputModel) {

         searchJobs = myData
      }
}

//AMRK:- Api Methods
extension JobOffersVC {
    
    func callGetSearchedJobs() {
        JobOrderServiceManager.shareInstance.getSearchedJobOrders(postData: searchJobs) { result in
            
            if let result = result {
                Swift.dump(result)
            }
        }
    }
© www.soinside.com 2019 - 2024. All rights reserved.