我的应用程序从服务器下载更新。为此,它将设备上的数据与服务器上的可用数据进行比较。如果不匹配,布尔值“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。
任何帮助将不胜感激。
在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)
}
将您的主要
ViewController
传递给 UpdateViewController
方法中的 prepareForSegue
。
完成更新后,更新
updateAvailable
控制器的 ViewController
标志。
这样,在主
ViewController
消失并出现时,ViewController中的updateAvailable将是YES
。
请记住设置 updateAvailable 标志和 UpdateViewController 中 ViewController 的引用为 public。到 能够在课堂之外更新这些值。
在我的第二个视图控制器上,我正在收集数据并希望将其发送回父控制器。一旦父控制器收到数据,我想触发名为
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)
}
}
}