当呈现的视图控制器被取消时调用呈现视图控制器的 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 上面所做的任何方式手动处理它。
我目前有一个基本视图控制器说 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 上面所做的任何方式手动处理它。