Combining Storyboards and XIBs in Xcode
You're zipping along prototyping your app using Interface Builder and storyboards. But now you want to reuse a scene all over the place. What do you do? Combine the power of storyboards and XIBs by mixing them!
You could segue from many different areas, but unless the view controller
behaves quite similarly, you'll soon run into issues with
IBAction mappings. The best solution? Use a XIB for those tricky areas.
You could also have the same
Controller.m files, but build
the scene in Interface Builder multiple times. But this is a pain to maintain
How do we do this? Quite simple actually. As always, a few assumptions first:
- We're using a
UITableViewControllersomewhere in the storyboard.
- When we click on a cell of the above table, we want to segue to our custom view controller. However, don't set up any segues related to this yet.
First off, create your new view controller, making sure it subclasses
UIViewController and that you tell Xcode to use a XIB. Let's call it
CustomViewController. Feel free to add buttons and labels to your XIB.
Connect outlets and actions as necessary.
Now head over to your main storyboard. Add an empty
UIViewController onto the
canvas and change the identity to
CustomViewController. Now here's the key
part: using the document outline1, find the
View listed under
Controller. Highlight it, and delete it.
And that's it! Now the storyboard will load your custom XIB whenever it segues to this view.
So what are the advantages? You can create segues back from this view to other parts of the storyboard. Granted, you'll have to call them manually, but this is a huge advantage.
Try it: control-drag from your placeholder controller in the storyboard back to
UITableViewController. Highlight the created segue, and in the Attribute
Inspector, rename it to
backToTable. Then in an
IBAction method inside
[self performSegueWithIdentifier:@"backToTable" sender:self];
Moreover, if all these controllers are embedded in
you'll get all these segues for free!
That's the side bar on the left when using Interface Builder. ↩