当呈现的视图控制器被取消时调用呈现视图控制器的 viewWillAppear 的问题

Issue with calling viewWillAppear of presenting view controller when presented one is dismissed

我目前有一个基本视图控制器说 AVC,它在当前上下文中呈现另一个视图控制器说 BVC,如下所示:

let bvc: BVC = sb.instantiateViewControllerWithIdentifier("BVC") as! BVC
bvc.modalPresentationStyle = UIModalPresentationStyle.OverCurrentContext
self.presentViewController(bvc, animated: true, completion: nil)

然后我在 BVC 中设置一个值并在关闭时使用相同的值在 AVC 的 viewWillAppear 中执行一个功能。但是,我注意到在呈现 OverCurrentContext 时,在关闭时,不会调用 viewWillAppear。

我该如何解决这个问题?我需要一个半透明的呈现视图,因此需要使用 OverCurrentContext。

谢谢!

巴拉,

两种方式,

方式一

您可以为此使用委托和协议:)

在BVC中声明协议并在AVC中确认。当你在 BVC 中完成调用协议的方法并让 AVC 关闭 BVC 并且通过这样做你可以将数据从 BVC 传递到还有一个VC。

示例:

在 BVC 中声明如下所示的协议

protocol letsCallParent{
    func amDoneHere(dataIwantToPass : String)
}

在 BVC

中声明一个 属性 以保存确认此协议的视图控制器的引用
var myParent : letsCallParent?

并且当你完成 BVC 并且你必须自己解散调用委托中的方法并传递你想要传递的数据时:)现在期望父( AVC) 解雇 BVC 而不是自己调用 dismissViewController :)

if let parent = myParent {
    parent.amDoneHere("Hi am Done here")
}

在 AVC 中使用

确认协议
class AVC: UIViewController,letsCallParent{

并在实例化 BVC 之后,在呈现之前将其自身指定为 BVC 的 myParent :)

let bvc: BVC = sb.instantiateViewControllerWithIdentifier("BVC") as! BVC
bvc.myParent = self

最后实现协议方法:)

func amDoneHere(dataIwantToPass: String) {
   print("\(dataIwantToPass)")
   //if you want to dismiss BVC call 
   //if you have pushed bvc
   //self.navigationController?.popToViewController(self, animated: true)
   //if you have presented
   //self.dismissViewControllerAnimated(true, completion: nil)
}

方法 2

利用unwind segue :)利用unwind segue将消除编写委托和协议的需要:)也为父视图控制器提供了访问子视图控制器的机会:) 一旦您有权访问子 VC,即 BVC,您就可以从中读取数据 :)

示例:

声明展开 segue :) 如果您希望 BVC 在 AVC 被取消时调用它,请在 AVC 中声明一个 unwind segue 方法 :)

@IBAction func cancelChildVC(segue:UIStoryboardSegue) {
        let childVC : SecondViewController = segue.sourceViewController as! SecondViewController
        print(childVC.name)
        self.dismissViewControllerAnimated(true, completion: nil)
}

方法的签名是固定的 :) 它必须是一个@IBAction 并且它必须接受 segue 作为参数 :)

仅在声明此方法后:)转到您的情节提要和select BVC并按住控件并从按钮或您在B[=74=中的任何其他视图拖动] 关闭它,退出 BVC 中的选项 :)

请查看下面提供的 gif 以获得清晰的理解:)

如果操作正确,您将看到在 AVC 中声明的方法作为弹出选项出现 :) select 它 :) 就是这样 :) 每当您点击您将控件从中拖动到 Exit 的按钮或视图,将调用 AVC 中的方法 :)

在 AVC 的方法中,您可以访问 BVC 实例,因为现在您可以访问 segue 实例 :) 记住直接 segues 的 prepareForSegue 方法,这类似于放松 segue :)

let childVC : SecondViewController = segue.sourceViewController as! SecondViewController
print(childVC.name)
self.dismissViewControllerAnimated(true, completion: nil) 

一旦您有权访问 BVC 访问其数据,请注意“segue.sourceViewController”的用法:)

希望我的回答对您有所帮助:)

问题说明

正如您所注意到的,当呈现 OverCurrentContext 时,viewWillAppear 不会在关闭时被调用。

为什么?

viewWillAppear 将在您返回视图时调用(以防视图已经消失)。当您使用 OverCurrentContext 呈现新视图时,主视图仍会出现,您会在其上方或部分上方呈现新视图!弹出效果 !

由于这种逻辑,当您关闭 OverCurrentContext 视图时,不会调用 viewWillAppear 并且您必须使用@Sandeep 上面所做的任何方式手动处理它。