iOS navigationcontroller中的back按钮的隐藏及右滑pop操作整理

iOS7之后系统支持了pop手势右滑自动调用back方法,这让我们省了很多事,不用自定义手势,不用自己写方法,只需要写几行代码,轻松搞定,代码如下:

//设置滑动回退
    __weak typeof(self) weakSelf = self;
    self.navigationController.interactivePopGestureRecognizer.delegate = weakSelf;
    //判断是否为第一个view
    if (self.navigationController && [self.navigationController.viewControllers count] == 1) {
        self.navigationController.interactivePopGestureRecognizer.enabled = YES;
    }

so easy!

注意:当前页面中的手势冲突

手势右滑pop弄好了,剩下的就是back按钮的问题了,大部分应用都是自定义back按钮,因为系统自带的back按钮功能单一,只能自定义image和title,不能重写target和action。也显得自己的应用比较个性化,但是在pop操作的时候,系统会自动显示上层viewcontroller中的back按钮,也就是上页面的title,其实隐藏也很简单,一行代码,但是隐藏的方法比较多,首先来看看back按钮都有哪些方法可以获取到:

self.navigationItem.backBarButtonItem
self.navigationController.navigationItem.backBarButtonItem
self.navigationController.navigationBar.backItem.backBarButtonItem

这三个对应隐藏的方法分别:

[self.navigationItem setHidesBackButton:YES];
[self.navigationController.navigationItem setHidesBackButton:YES];
[self.navigationController.navigationBar.backItem setHidesBackButton:YES];

这三个方法都可以隐藏back按钮,但是第一种方法设置后,在二级页面当手势右滑一半的时候会显示上层页面的back按钮,其他两种方法都可以完美隐藏掉back按钮。

下面是 iOS Navigation Controller 常用的一些方法的详解: 1. pushViewController:animated: 方法:将一个新的视图控制器推入导航栈,并在导航条上显示一个新的视图控制器的标题和返回按钮。可以通过 animated 参数来控制是否显示动画效果。 2. popViewControllerAnimated: 方法:从导航栈弹出当前的视图控制器,并返回上一个视图控制器。可以通过 animated 参数来控制是否显示动画效果。 3. popToViewController:animated: 方法:从导航栈弹出所有在指定视图控制器之上的视图控制器,并返回到指定的视图控制器。可以通过 animated 参数来控制是否显示动画效果。 4. popToRootViewControllerAnimated: 方法:从导航栈弹出所有的视图控制器,并返回到根视图控制器。可以通过 animated 参数来控制是否显示动画效果。 5. setViewControllers:animated: 方法:设置导航栈的所有视图控制器,并可以通过 animated 参数来控制是否显示动画效果。 6. topViewController 属性:获取当前导航栈的顶部视图控制器。 7. visibleViewController 属性:获取当前导航栈可见的视图控制器。 8. navigationBar 属性:获取导航条对象,可以通过该对象修改导航条的样式或添加自定义视图。 以上是 iOS Navigation Controller 常用的一些方法和属性的详解,掌握这些方法可以更好地实现导航控制器的功能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值