Swift – 使用popViewController并将数据传递给您要返回的ViewController

Swift – 使用popViewController并将数据传递给您要返回的ViewController,第1张

概述我在我的第一个视图控制器上有一个名为showSettings的可选bool变量,它叫做ViewController,我从SecondViewControllerd出回ViewController. 在我d出之前,我想将bool设置为true.由于ViewController在内存中,因此实例化另一个视图控制器似乎是错误的. 最好的方法是什么?我不使用故事板,如果这对你的答案很重要. 谢谢你的帮助 我在我的第一个视图控制器上有一个名为showSettings的可选bool变量,它叫做VIEwController,我从SecondVIEwControllerd出回VIEwController.

在我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所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1033444.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-24
下一篇 2022-05-24

发表评论

登录后才能评论

评论列表(0条)

保存