Without using a storyboard we could simply drag a UIView
onto the canvas, lay it out and then set it in the tableView:viewForHeaderInSection
or tableView:viewForFooterInSection
delegate methods.
How do we accomplish this with a StoryBoard where we cannot drag a UIView onto the canvas
Just use a prototype cell as your section header and / or footer.
tableView:viewForHeaderInSection:
method or the tableView:viewForFooterInSection:
method[tableView dequeueReusableCellWithIdentifier:]
to get the headertableView:heightForHeaderInSection:
method.-(UIView *) tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section { static NSString *CellIdentifier = @"SectionHeader"; UITableViewCell *headerView = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; if (headerView == nil){ [NSException raise:@"headerView == nil.." format:@"No cells with matching CellIdentifier loaded from your storyboard"]; } return headerView; }
Edit: How to change the header title (commented question):
tableView:viewForHeaderInSection:
method get the label by calling: UILabel *label = (UILabel *)[headerView viewWithTag:123];
[label setText:@"New Title"];
I know this question was for iOS 5, but for the benefit of future readers, note that effective iOS 6 we can now use dequeueReusableHeaderFooterViewWithIdentifier
instead of dequeueReusableCellWithIdentifier
.
So in viewDidLoad
, call either registerNib:forHeaderFooterViewReuseIdentifier:
or registerClass:forHeaderFooterViewReuseIdentifier:
. Then in viewForHeaderInSection
, call tableView:dequeueReusableHeaderFooterViewWithIdentifier:
. You do not use a cell prototype with this API (it's either a NIB-based view or a programmatically created view), but this is the new API for dequeued headers and footers.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With