在我d出之前,我想将bool设置为true.由于VIEwController在内存中,因此实例化另一个视图控制器似乎是错误的.
最好的方法是什么?我不使用故事板,如果这对你的答案很重要.
谢谢你的帮助
所以我想出来的主要是基于这篇文章 – http://makeapppie.com/2014/09/15/swift-swift-programmatic-navigation-view-controllers-in-swift/在SecondVIEwController中,在类声明之上,添加以下代码:
protocol SecondVCDelegate { func dIDFinishSecondVC(controller: SecondVIEwController)}
然后在SecondVIEwContoller里面添加一个类变量:
var delegate:MeditationVCDelegate! =没有
然后在你的按钮所针对的函数内部添加:
self.navigationController?.popVIEwControllerAnimated(true)delegate.dIDFinishSecondVC(self)
我们在这里做的是在SecondVIEwController中执行pop,而不传递任何数据,但由于我们已经定义了一个协议,我们将在VIEwController中使用它来处理数据.
接下来,在VIEwController中,将您在SecondVIEwController中定义的协议添加到VIEwController继承的类列表中:
class VIEwController: UIVIEwController,SecondVCDelegate { ... your code... }
您需要添加我们在新协议中定义的函数,以使编译器满意.在VIEwController的类中,添加以下内容:
func dIDFinishSecondVC(controller: SecondVIEwController) { self.myBoolVar = true controller.navigationController?.popVIEwControllerAnimated(true)}
在我们调用dIDFinishSecondVC的SecondVIEwController中,我们在VIEwController类中调用此方法,我们正在d出的控制器.它类似于我们在SecondVIEwController中编写这个代码,但是我们已经在VIEwController中编写了它,我们正在使用委托来管理两者之间的消息传递.
最后,在我们的目标是推送到SecondVIEwController的函数中,添加以下代码:
let secondVC = secondVIEwController()secondVC.delegate = selfself.navigationController?.pushVIEwController(secondVC,animated: true)
而已!您应该设置为在两个视图控制器之间传递代码而不使用故事板!
总结以上是内存溢出为你收集整理的Swift – 使用popViewController并将数据传递给您要返回的ViewController全部内容,希望文章能够帮你解决Swift – 使用popViewController并将数据传递给您要返回的ViewController所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)