自定义UINavigationController的后退按钮标题

转载 2015年11月19日 18:58:19

http://zgia.net/?tag=backbarbuttonitem

A视图进入B视图,如下,self指的A,bView指的B。

一开始想当然的,在B视图的viewDidLoad里直接使用:

来更改后退按钮标题,结果后退后,发现A视图的导航栏标题也变成“back”了。

于是网上搜了一下,别人推荐在B视图的viewDidLoad/viewWillAppear里使用:

我试了,发现无效。

无奈之下,只好研读UINavigationController Class Reference去,在“Updating the Navigation Bar”小节,有这么一段话:

The bar button item on the left side of the navigation bar allows for navigation back to the previous view controller on the navigation stack. The navigation controller updates the left side of the navigation bar as follows:

  • If the new top-level view controller has a custom left bar button item, that item is displayed. To specify a custom left bar button item, set the leftBarButtonItem property of the view controller’s navigation item.
  • If the top-level view controller does not have a custom left bar button item, but the navigation item of the previous view controller has a valid item in its backBarButtonItem property, the navigation bar displays that item.
  • If a custom bar button item is not specified by either of the view controllers, a default back button is used and its title is set to the value of the title property of the previous view controller—that is, the view controller one level down on the stack. (If there is only one view controller on the navigation stack, no back button is displayed.)

我大致解释一下,使用pushViewController切换到下一个视图时,navigation controller按照以下3条顺序更改导航栏的左侧按钮。

1、如果B视图有一个自定义的左侧按钮(leftBarButtonItem),则会显示这个自定义按钮;

2、如果B没有自定义按钮,但是A视图的backBarButtonItem属性有自定义项,则显示这个自定义项;

3、如果前2条都没有,则默认显示一个后退按钮,后退按钮的标题是A视图的标题。

按照这个解释,我把UIBarButtonItem *backItem……这段代码放在A视图的pushViewController语句之前。

OK问题解决了,B视图的后退按钮的标题变成back了。

    UIBarButtonItem *backItem1 = [[UIBarButtonItem alloc] initWithTitle:@"12321" style:UIBarButtonItemStyleBordered target:nil action:nil];
    
    
   [self.navigationItem setBackBarButtonItem:backItem1];


举报

相关文章推荐

自定义UINavigationController的后退按钮标题

转载自:http://zgia.net/?tag=backbarbuttonitem A视图进入B视图,如下,self指的A,bView指的B。 1[self.na...

iOS 全局修改UINavigation 后退按钮

快两年没有更新blog了,现在有点时间随便写点东西吧。 做iOS项目中,可能会经常遇到要定制后退按钮的情况,比如把后退按钮的title固定为“返回”(修改title对后面push的vc生效),比如用...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

如何让浏览器上的后退按钮无效

 方法1 2. 3. 4. 7. 8. 9. 10. 11. 12. 13.I am newfile2!!!!!!!!!! 14. 15. ...

自定义UINavigationController 标题、左右边按钮 navigationbar 设置多个按钮

#import @interface ILNavigationController : UINavigationController @end

Android自定义带按钮标题栏

1.修改res/values中的styles.xml,这是为了自定义app的主题样式,在这里可以设置标题栏的宽度、背景颜色 #337ab7 ...

ionic删除后退按钮文字

修改ionic.bundle.js中53149行代码,// buttonEle.appendChild(buttonTextEle);ionic版本不同,位置可能不一样.具体参考下面代码if (!ha...

UINavigationController 改变返回按钮的标题

改变NavigationController的back button的标题  一般来说这个标题,是上个页面的title, 例如从A页面 push 进来一个B页面,A的title 为 ...

自定义按钮

package com.zqgame.army.contrl { /** *@author zhoujie *@date 2011-7-11 **/ import com....

自定义按钮组,需自定义按钮配合

package com.zqgame.army.contrl { /** * 按钮组 *@author zhoujie *@date 2011-7-26 **/ im...

Android之自定义背景按钮、自定义形状按钮

在Android开发应用中,默认的Button是由系统渲染和管理大小的。而我们看到的成功的移动应用,都是有着酷炫的外观和使用体验的。因此,我们在开发产品的时候,需要对默认按钮进行美化。在本篇里,笔者结...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)