这个知识点经常容易忘记,好多人都是遇到了头大,看到了心烦,然后费尽脑力查看文档,查看以前的笔记。不过也应了一句老话便是“好记性,不如一个烂笔头”。废话不多,来点干货:
导航的返回按钮的加载原理是这样的:
1、如果B视图有一个自定义的左侧按钮(leftBarButtonItem),则会显示这个自定义的按钮;
2、如果B没有自定义的按钮,但是A视图的backBarButtonItem属性有自定义项,则显示这个自定义项;
3、如果如果前两条都没有的话,则默认显示一个后退按钮并且显示父视图的Title,而如果其父视图没有设置Title的话,则默认显示Back;
按照这样的解释,我们可以把自定义的UIBarButtonItem *backItem......这段代码放在A视图的pushViewController语句之前。
具体实现:
在A视图的代码中:
UIBarButtonItem *backBarButtonItem = [[UIBarButtonItem alloc]init];
backBarButtonItem.title =@"BarButtonItemTitle";
self.navigationItem.backBarButtonItem = backBarButtonItem;
一般情况下,我们可以把这段代码放在- (void)viewDidLoad
- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath
{
self.backBarButtonItem.title = myArray[index.row];
}
可以注意到我们并没有在B视图的代码中设置任何东西,B视图的导航栏上的返回按钮的Title也就可以自定义了。这就是我们在设置自定义导航栏时容易疏忽的一点,即如果我们有需求设置导航栏的返回按钮的时候,我们需要在其上一级视图中进行如上设置。
设置结果为:
另外,我们也可以在B视图中做这样的设置:
UIBarButtonItem *leftBarButtonItem = [[UIBarButtonItem alloc]init];
leftBarButtonItem.title = @"title";
self.navigationItem.leftBarButtonItem = leftBarButtonItem;
但是这种设置的显示结果是:
很显然这种效果并不是我们想要到,再者如果想回到上一级视图的话必须要给这个按钮添加一个回调方法。
还有,你也可以通过控制A视图的Title来设置B视图的导航栏的返回按钮的title,不过这种方法对于简单视图是可以的,即这个视图的title只有一个并且不改变。但对于比较复杂的视图布局,这种方法还是比较繁琐的。要在A视图的代码中对title进行不断更新设置。