网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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

需求

网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、成都微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了蓬莱免费建站欢迎大家使用!

之前已经实现了自定义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再次点击实现刷新效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!


当前文章:iOS开发中TabBar再次点击实现刷新效果
新闻来源:http://bjjierui.cn/article/gjogop.html

其他资讯