关闭 ViewController 并重新加载之前的数据/传回数据?

ner*_*rgy 5 cocoa-touch delegates uiviewcontroller swift swift2

我的应用程序从服务器下载更新。为此,它将设备上的数据与服务器上的可用数据进行比较。如果不匹配,布尔值“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"
    }
}
Run Code Online (Sandbox Code Playgroud)


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

 @IBAction func getUpdateLabelPressed(sender: UITapGestureRecognizer) {
    if updateAvailable{
        self.performSegueWithIdentifier("segueToUpdateView", sender: self)
    }
Run Code Online (Sandbox Code Playgroud)



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)
            }
        }
     })       
}
Run Code Online (Sandbox Code Playgroud)


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

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

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

我怎样才能关闭 UpdateViewController重新加载以前的 ViewController发送回触发 ViewController 的 updateChecker() 方法的数据?或者清除整个 ViewControllerStack 并重新启动应用程序?

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

任何帮助将不胜感激。

Evg*_*nii 2

在 UpdateViewController 中创建一个闭包属性clearUpdateAvailable

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

  override func viewWillDisappear(animated: Bool) {
    super.viewWillDisappear(animated)
    clearUpdateAvailable?()
  }
}
Run Code Online (Sandbox Code Playgroud)

您可以clearUpdateAvailable在 viewWillDisappear 中调用,也可以在从服务器接收数据的方法中调用。

在 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)
}
Run Code Online (Sandbox Code Playgroud)