iOS开发中TabBar再次点击实现刷新效果

发布时间:2020-09-12 04:18:08 作者:mrr
来源:脚本之家 阅读:157

需求

之前已经实现了自定义TabBar,如图所示:

iOS开发中TabBar再次点击实现刷新效果 

自定义TabBar.jpeg

现在需要实现一个类似今日头条TabBar的功能 —— 如果继续点击当前TabBar的选中项,那么该界面需要刷新UITableView。

分析

既然已经自定义了TabBar,那么最简单的就是在自定义中给TabBar中需要的UITabBarButton添加事件 —— 点击就发送通知,并且将当前的索引传出去。对应的界面监听通知,拿到索引比对,如果和当前索引一致,就执行对应的操作。

实现

1. 自定义TabBar的layoutSubviews中绑定事件

- (void)layoutSubviews
{
 [super layoutSubviews];
 for (UIButton * tabBarButton in self.subviews) {
  if ([tabBarButton isKindOfClass:NSClassFromString(@"UITabBarButton")]) {
   //监听tabbar的点击
   //绑定tag 标识
   tabBarButton.tag = index;
   //监听tabbar的点击
   [tabBarButton addTarget:self action:@selector(tabBarButtonClick:) forControlEvents:UIControlEventTouchUpInside];
  }
 }
}

2. 监听事件,发送通知

- (void)tabBarButtonClick:(UIControl *)tabBarBtn{
 
 //判断当前按钮是否为上一个按钮
 //再次点击同一个item时发送通知出去 对应的VC捕获并判断
 if (self.previousClickedTag == tabBarBtn.tag) {
  
  [[NSNotificationCenter defaultCenter] postNotificationName:
   @"DoubleClickTabbarItemNotification" object:@(tabBarBtn.tag)];
 }
 self.previousClickedTag = tabBarBtn.tag;
}

对应的UIViewController监听通知

- (void)viewDidLoad {
 [super viewDidLoad];
 [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(doubleClickTab:) name:@"DoubleClickTabbarItemNotification" object:nil];
}

3. 监听到通知,比对后执行操作

-(void)doubleClickTab:(NSNotification *)notification{
 //这里有个坑 就是直接用NSInteger接收会有问题 数字不对
 //因为上个界面传过来的时候封装成了对象,所以用NSNumber接收后再取值
 NSNumber *index = notification.object;
 if ([index intValue] == 1) {
  //刷新
 }
}

最终的效果请看:

iOS开发中TabBar再次点击实现刷新效果

总结

以上所述是小编给大家介绍的iOS开发中TabBar再次点击实现刷新效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对亿速云网站的支持!

推荐阅读:
  1. 微信小程序中如何实现返回tabBar不刷新页面
  2. Vue如何实现前进刷新后退不刷新的效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

ios tabbar 点击

上一篇:SpringBoot使用CXF集成WebService的方法

下一篇:Fusioncharts:面向Web和移动端的Javascript 图表

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》