DetailViewController:
@IBOutlet var selectedBundesland: UILabel!
TableViewController:
override func prepareForSegue
Recently had this problem. The problem was that I had dragged the segue from a specific object from my current view controller to the destination view controller - do not do this if you want to pass values.
Instead drag it from the yellow block at the top of the window to the destination view controller. Then name the segue appropriately.
Then use the if (segue.identifier == "BackToCalculator")
to assign the value as you are currently. All should work out!
While the correct solution is to store the text and attach it to the label later in viewDidLoad
or something, for testing proposes, you can bypass the issue by forcing the destinationViewController
to build itself from storyboard by calling its view
property like:
override func prepare(for segue: UIStoryboardSegue, sender: Any?){
if (segue.identifier == "TestViewController") {
var vc:FirstViewController = segue.destination as! TestViewController
print(vc.view)
vc.testLabel.text = "Hello World!"
}
}
made for Swift 3.0 with love
DetailViewController:
var textValue: String = ""
@IBOutlet weak var selectedBundesland: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
selectedBundesland.text = textValue
}
TableViewController:
if (segue.identifier == "BackToCalculator") {
var vc:FirstViewController = segue.destinationViewController as FirstViewController
vc.textValue = "Test"
}
You cannot write directly to the UILabel
in prepareForSegue
because the view controller is not fully initialised yet. You need to create another string property to hold the value and put it into the label in the appropriate function - such as viewWillAppear
.
I just had the same problem, I solved it by defining a string that is not connected to an outlet in the new view controller and than referring to it in the prepareForSegue() method, in the new VC I made the label outlet to take the value of the non connected string in the viewDidLoad() method.
Cheers