Sie könnten delegation verwenden.
Zuerst ein Delegate-Protokoll deklarieren. Dies sollte in Ihrer NoteDetailViewController.swift
Datei sein, aber außerhalb der class
Erklärung:
protocol NoteDetailViewControllerDelegate: class {
func noteDetailViewControllerButtonTouched(controller: NoteDetailViewController)
}
Als nächstes einen Delegaten Eigenschaft zu Ihrem NoteDetailViewController
hinzufügen:
weak var delegate: NoteDetailViewControllerDelegate?
Jetzt verwenden wir die @IBAction
den Delegierten zu sagen, was wird die ListTableViewController
:
@IBAction func funcButTouched(sender: UIButton)
{
delegate?.noteDetailViewControllerButtonTouched(self)
}
schließlich in ListTableViewController
, zurück (assum ing diesen Controller wird direkt die vor einem NoteDetailViewController
) gezeigt wird, entsprechen prepareForSegue
das Protokoll und verwenden Sie die Delegierten selbst zu setzen:
class ListTableViewController: UITableViewController, NoteDetailViewControllerDelegate {
// ... more stuff ...
// Implement the delegate protocol
func noteDetailViewControllerButtonTouched(controller: NoteDetailViewController) {
// Do something! The button was pressed!
wordCount()
}
// Set ourselves as delegate when we are about to show the other view controller
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
if let yourVC = segue.destinationViewController as? NoteDetailViewController {
yourVC.delegate = self
}
}
}
Sie mit so etwas wie diesem beenden sollten:
NoteDetailViewController.swift
:
class NoteDetailViewController: UIViewController
{
@IBOutlet weak var funcButton: UIButton!
weak var delegate: NoteDetailViewControllerDelegate?
@IBAction func funcButTouched(sender: UIButton)
{
delegate?.noteDetailViewControllerButtonTouched(self)
}
}
protocol NoteDetailViewControllerDelegate: class {
func noteDetailViewControllerButtonTouched(controller: NoteDetailViewController)
}
ListTableViewController.swift
:
class ListTableViewController: UITableViewController, NoteDetailViewControllerDelegate
{
// the function
func wordCount()
{
var contentArr = Project.sharedInstance.content.componentsSeparatedByString(" ")
for (index, element) in contentArr.enumerate()
{
let location = conciseArr.indexOf(element)
if (location != nil)
{
contentArr[index] = inflatedArr[location!]
afterStr = contentArr.joinWithSeparator(" ")
Project.sharedInstance.after = afterStr
}
}
}
// Implement the delegate protocol
func noteDetailViewControllerButtonTouched(controller: NoteDetailViewController) {
// Do something! The button was pressed!
wordCount()
}
// Set ourselves as delegate when we are about to show the other view controller
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
if let yourVC = segue.destinationViewController as? NoteDetailViewController {
yourVC.delegate = self
}
}
}
Ich bin nicht sicher, ich verstehe, was Sie fragst du? –
Können Sie mir Ihre UIViewController-Hierarchie zeigen? –
Die Reihenfolge meiner View-Controller? Es geht ListTableViewController zu NoteDetailViewController –