swift 是否解除ViewController并重新加载以前的数据/传回数据?

kkih6yb8  于 2023-01-01  发布在  Swift
关注(0)|答案(3)|浏览(159)

我的应用从服务器下载更新。为此,它会将设备上的数据与服务器上可用的数据进行比较。如果不匹配,则将布尔值“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重新加载以前的ViewController发回触发ViewController的updateChecker()方法的数据?清除整个ViewControllerStack并重新启动应用?
我理解委托安排似乎是合适的,但是之前关于这个主题的SO问题和答案(例如this one)是针对Objective-C的,我无法将这些答案改编为Swift 2.0。
任何帮助都将不胜感激。

wgeznvg7

wgeznvg71#

在UpdateViewController中创建闭包属性clearUpdateAvailable

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

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

您可以在viewWillDisappere或从服务器接收数据的方法中调用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)
}
fhg3lkii

fhg3lkii2#

将主ViewController传递给prepareForSegue方法中的UpdateViewController
完成更新后,更新ViewController控制器的updateAvailable标志。
这样,在主ViewController消失和出现时,ViewController中的updateAvailable将为YES
请记住将updateAvailable标志的可访问性和UpdateViewController中ViewController的引用设置为public.,以便能够在类外部更新这些值。

aiazj4mn

aiazj4mn3#

在我的第二个视图控制器上,我正在收集数据,并希望将其发送回Perent控制器。一旦父控制器收到数据,我希望激发名为“callGetSearchedJobs()"的函数。但在第二个视图控制器被解除后,它没有被调用。
覆盖函数视图Did消失(_ animated:布尔值){

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

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

第一个视图控制器:
扩展职务提供VC:作业填充器VC委托{
函数发送数据至工作机会VC(我的数据:搜索作业输入模型){

searchJobs = myData
  }

}
//AMRK:- API方法扩展JobOffersVC{

func callGetSearchedJobs(){
    JobOrderServiceManager.shareInstance.getSearchedJobOrders(postData: searchJobs){ result in
        
        if let result = result{
            Swift.dump(result)
        }
    }
}

相关问题