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。
任何帮助将不胜感激。
在 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)
| 归档时间: |
|
| 查看次数: |
2491 次 |
| 最近记录: |