36选7玩法 >iOS开发

iOS开发之TabBar再次点击实现刷新

2018-04-25 14:25 编辑: suiling 分类:iOS开发 来源:YungFan

需求

之前已经实现了自定义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开发之UIRefreshControl使用踩坑

作者:YungFan

链接:https://www.jianshu.com/p/fdc8ad60c4c0

搜索CocoaChina微信公众号:CocoaChina
微信扫一扫
订阅每日移动开发及APP推广热点资讯
公众号:
CocoaChina
我要投稿   收藏文章
上一篇:追踪Objective-C方法中的Block参数对象
下一篇:iOS开发之UIRefreshControl使用踩坑

相关资讯

我来说两句
发表评论
您还没有登录!请登录注册
所有评论(0

综合评论

相关帖子

sina weixin mail 回到顶部
幸运飞艇5码公式 | 幸运飞艇开奖直播app | 北京pk | 幸运农场官网 | 重庆幸运农场预测结果 | 重庆幸运农场开奖历史 | 北京赛车pk10高手心得 | 幸运飞艇定位公式 |