我有我的地方是UINavigationBar的不弹出它的项目时,弹出的UINavigationController视图控制器的问题。
我有一个看看栈观察以下几点:
- 预期数量分配的导航控制器(在仪器选中)
- 有堆栈上控制器的正确数目。 (调试日志)
- 导航项目不被弹出。 (调试日志)
这里就是我所做的。
我打开一些日志语句插入viewDidLoad方法调用超之后。
NSLog(@"%@", [self navigationController]);
NSLog(@"%@", [[self navigationController] viewControllers]);
NSLog(@"%@", [[self navigationController] navigationBar]);
NSLog(@"%@", [[[self navigationController] navigationBar] items]);
后的初始视图被加载。
2009-10-09 16:42:51.706 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:42:51.720 Bob[11657:207] (
<MediaBrowser: 0x2354c0>
)
2009-10-09 16:42:51.742 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:42:51.758 Bob[11657:207] (
<UINavigationItem: 0x242d60>
)
一切看起来不错。 推动第二控制器。
2009-10-09 16:43:11.800 Bob[11657:207] -[MediaBrowser beginLoading] [Line 261]
2009-10-09 16:43:12.320 Bob[11657:207] -[MediaBrowser loadingComplete] [Line 269]
2009-10-09 16:43:12.587 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:43:12.654 Bob[11657:207] (
<MediaBrowser: 0x2354c0>,
<MediaBrowser: 0x2c1cc0>
)
2009-10-09 16:43:12.685 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:43:12.734 Bob[11657:207] (
<UINavigationItem: 0x242d60>,
<UINavigationItem: 0x2c63b0>
)
再没有什么意外的在这里。 推第三控制器。
2009-10-09 16:43:19.934 Bob[11657:207] -[MediaBrowser beginLoading] [Line 261]
2009-10-09 16:43:20.388 Bob[11657:207] -[MediaBrowser loadingComplete] [Line 269]
2009-10-09 16:43:20.928 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:43:20.962 Bob[11657:207] (
<MediaBrowser: 0x2354c0>,
<MediaBrowser: 0x2c1cc0>,
<MediaBrowser: 0x4027e20>
)
2009-10-09 16:43:21.003 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:43:21.039 Bob[11657:207] (
<UINavigationItem: 0x242d60>,
<UINavigationItem: 0x2c63b0>,
<UINavigationItem: 0x4028880>
)
都好。 现在,让我们弹出一个控制器
2009-10-09 16:43:26.935 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:43:26.945 Bob[11657:207] (
<MediaBrowser: 0x2354c0>,
<MediaBrowser: 0x2c1cc0>
)
2009-10-09 16:43:26.964 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:43:26.977 Bob[11657:207] (
<UINavigationItem: 0x242d60>,
<UINavigationItem: 0x2c63b0>,
<UINavigationItem: 0x4028880>
)
姆。 有什么不妥去。 控制器已弹出但导航产品依然存在。 为了让笑声再次推。
009-10-09 16:44:05.878 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:44:05.908 Bob[11657:207] (
<MediaBrowser: 0x2354c0>,
<MediaBrowser: 0x2c1cc0>,
<MediaBrowser: 0x407eb00>
)
2009-10-09 16:44:05.951 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:44:05.996 Bob[11657:207] (
<UINavigationItem: 0x242d60>,
<UINavigationItem: 0x2c63b0>,
<UINavigationItem: 0x4028880>,
<UINavigationItem: 0x407f280>
)
控制器堆叠看起来不错,导航项目堆栈在许多麻烦。 让我们跳出最后一次。
2009-10-09 16:44:17.770 Bob[11657:207] <UINavigationController: 0x243bb0>
2009-10-09 16:44:17.776 Bob[11657:207] (
<MediaBrowser: 0x2354c0>,
<MediaBrowser: 0x2c1cc0>
)
2009-10-09 16:44:17.785 Bob[11657:207] <UINavigationBar: 0x243e50; frame = (0 20; 320 44); autoresize = W; layer = <CALayer: 0x243ed0>>
2009-10-09 16:44:17.793 Bob[11657:207] (
<UINavigationItem: 0x242d60>,
<UINavigationItem: 0x2c63b0>,
<UINavigationItem: 0x4028880>,
<UINavigationItem: 0x407f280>
)
所以控制器堆栈罚款。 在另一方面导航项目有一些问题。
我难倒。 我知道我在做一些奇怪的/不可思议/错误的,但该死的我,如果我能看到后援只操纵我要去准备(通过我的控制器navigationItem属性)的自定义rightBarItem。
如果你走到这一步,谢谢。 在那里我可以从这里去思考,将不胜感激。