gpt4 book ai didi

swift - 从展开中保存更改。与 <返回一起工作

转载 作者:行者123 更新时间:2023-11-28 07:27:26 25 4
gpt4 key购买 nike

我无法理解我可以用默认的 Back BarButtonItem 做什么,以及我可以如何启动倒带。

下面显示了一个简化的布局。我在导航 Controller 中嵌入了一个 ViewController 并添加了一个 BarButtonItem(“显示”)并连接到第二个 VC。这会将“后退”按钮添加到第二个 Controller ,如下所示。 Basic Back Button

在第一个 VC 中,我将向用户展示一些细节,在第二个 VC 中,将展示更多细节。使用显示按钮和默认后退按钮,用户可以轻松地以预期的行为来回导航。

我的问题在于,用户将被允许修改“此处有更多详细信息”,我需要在用户放松后将其传递给第一个 VC。

我无法通过控制从“返回”图标拖动到“退出”图标,但我确定可以使用导航栏上的“保存”按钮执行此操作,如图所示。 (首先将 Navigation Item 拖到顶部,然后是 BarButtonItem)然后按住 control 拖到退出图标。

With Save Button

使用“保存”按钮,我可以启动一个 segue unwind,并使用如下代码在我的第一个 VC 中捕获更改。

   @IBAction func unwindFromSecondVC(_ sender: UIStoryboardSegue) {       
if sender.source is AddCharacterViewController {
if let senderVC = sender.source as? SecondViewController {
details = senderVC.newDetails
}
}
}

当用户进行更改然后单击后退按钮从而丢失更改时,这会产生问题。

我的首选解决方案是让后退按钮启动 segue 并传输更改。但这似乎不可能。我的第二个解决方案是让后退按钮通知尚未进行传输并停止展开序列。根据我的研究,这两种方法似乎都不可行。

在为用户提供常见的后退导航的同时,我应该如何最好地处理这个问题?

最佳答案

如果你想保存用户在第二个 VC 中所做的任何更改,你可以创建一个 SecondVCDelegate:

protocol SecondVCDelegate : class {
func detailsDidChange(newDetails: String)
}

SecondVC中,声明一个delegate属性:

weak var delegate: SecondVCDelegate?

每当细节发生变化(文本字段的值发生变化,或发生任何事件)时,您调用

delegate?.detailsDidChange(newDetails: newDetails)

FirstVC.prepareForSegue中,你应该设置self作为SecondVC的委托(delegate):

if let vc = segue.destination as? SecondVC {
vc.delegate = self
}

// ...

extension FirstVC : SecondVCDelegate {
func detailsDidChange(newDetails: String) {
details = newDetails
}
}

这样,每当 newDetails 发生变化时,FirstVC 都会收到通知。

如果您只想在用户离开 SecondVC 时通知 FirstVC,您可以改为调用 SecondVC.viewWillDisappear 中的委托(delegate)或方法就像那样。

关于swift - 从展开中保存更改。与 <返回一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56060912/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com