美文网首页
[ iOS 开发] LRFactory 之 LRVCExtend

[ iOS 开发] LRFactory 之 LRVCExtend

作者: leoRR | 来源:发表于2020-04-30 22:26 被阅读0次

    LRFactory

    这个库是基于自己以往 iOS 开发的工作经历,对一些常用的控件做的一些封装,提供了一些有意思的扩展,有兴趣的朋友可以了解一下,并希望能指出不足之处以及未考虑完善的地方。大家互相学习进步。

    LRVCExtend

    这个模块针对 ViewController 进行了一些有帮助的扩展

    可以帮助你更快的实现需求

    如何使用

    //通过 Cocoapods 安装
    pod 'LRFactory/LRVCExtend'
    
    //引入头文件
    #import <LRVCExtend.h>
    

    具体扩展内容如下


    LRFAppear

    针对 Appear, Disappear 进行的扩展,可以帮助你判断该次 Appear 是否是第一次 Appear,该次 Disappear 是否是最后一次 Disappear

    你只需要在子类按需重写以下这三个方法并添上你的相关业务。

    // 需子类重写, 默认空实现
    // 页面将要第一次显示
    - (void)lrf_viewWillAppearFirstTime:(BOOL)animated;
    // 页面将要永远消失
    - (void)lrf_viewWillDisappearForever:(BOOL)animated;
    // 页面已经永远消失
    - (void)lrf_viewDidDisappearForever:(BOOL)animated;
    

    当然,这里也提供了 block 的方式,让你可以随时可以添加业务。你只需要在需要的时候添加 action 就可以完成。

    // 添加页面将要显示的事件
    - (void)lrf_addActionWhileViewWillAppear:(void(^)(BOOL animated, BOOL isFirstTime))action;
    // 添加页面已经显示的事件
    - (void)lrf_addActionWhileViewDidAppear:(void(^)(BOOL animated))action;
    // 添加页面将要消失的事件
    - (void)lrf_addActionWhileViewWillDisappear:(void(^)(BOOL animated, BOOL isForever))action;
    // 添加页面已经消失的事件
    - (void)lrf_addActionWhileViewDidDisappear:(void(^)(BOOL animated, BOOL isForever))action;
    

    例:

    UIViewController *vc = [[UIViewController alloc] init];
    
    // 当 vc willAppear 的时候将会调用打印方法
    [vc lrf_addActionWhileViewWillAppear:^(BOOL animated, BOOL isFirstTime) {
        NSLog(@"ViewWillAppear isFirstTime:%d", isFirstTime);
    }];
    

    LRFGesture

    提供了一个属性,可以在有导航的页面里,让你很方便的决定一个页面是否支持向右滑动返回上一个页面

    @property (nonatomic, assign) BOOL lrf_canGesturePop;//手势右滑返回, 默认YES
    

    当设置为 YES 时,支持右滑返回,默认 YES

    当设置为 NO 时,禁用右滑返回

    例:

    UIViewController *vc = [[UIViewController alloc] init];
    
    // 禁用 vc 的右滑返回
    vc.lrf_canGesturePop = NO;
    

    LRFPresent

    对 present dismiss 方法进行扩展,可以方便的添加额外信息供你使用,并提供 willDismiss 及 didDismiss 的block供你使用

    //  弹出界面,带弹出界面消失的回调信息
    - (void)lrf_presentViewController:(UIViewController *)viewControllerToPresent animated:(BOOL)flag completion:(void (^ __nullable)(void))completion willDismissCallback:(void(^ __nullable)(id _Nullable info))willDismissCallback didDismissCallback:(void(^ __nullable)(id _Nullable info))didDismissCallback;
    
    //  消失界面,带回调信息
    - (void)lrf_dismissViewControllerAnimated:(BOOL)flag completion:(void (^ __nullable)(void))completion info:(id _Nullable)info;
    

    例:

    // present 视图
    [vcA lrf_presentViewController:vcB animated:YES completion:^{
        NSLog(@"completion");
    } willDismissCallback:^(NSDictionary * _Nullable info) {
        NSLog(@"willDismissCallback %@", info);
    } didDismissCallback:^(NSDictionary * _Nullable info) {
        NSLog(@"didDismissCallback %@", info);
    }];
    
    // dismiss 视图
    [vcB lrf_dismissViewControllerAnimated:YES completion:^{
        NSLog(@"completion");   
    } info:@{@"info":@"something interesting"}];
    

    LRFPush

    提供了一个有意思的属性,通过他,你能很方便的在导航返回时,跳过一些你想跳过的页面

    @property (nonatomic, assign) BOOL lrf_popIgnore;// pop 时忽略该页面, 默认NO
    

    例:

    // 导航 push 到 vcA
    [navigationController pushViewController:vcA animated:YES];
    
    // 导航 push 到 vcB
    [navigationController pushViewController:vcB animated:YES];
    
    // 设置 vcB pop 时忽略的属性为 YES ,
    // 建议在 push 下一个页面时候设置该属性,也是这个时候你能够知道 push 到下个页面时,该页面是否还有存在的必要
    vcB.lrf_popIgnore = YES;
    
    // 导航 push 到 vcC
    [navigationController pushViewController:vcC animated:YES];
    
    // 导航返回上一个页面,此时页面回到 vcA ,而 vcB 已经被忽略了
    [navigationController popViewControllerAnimated:YES];
    

    LRFTabBar

    提供了一个类方法,能够帮你当有 tabbar 的时候,导航 push 之后自动隐藏 tabbar

    + (void)lrf_autoHidesTabBar;
    

    例:

    // 只需在项目启动的时候配置一下就可以了
    [UIViewController lrf_autoHidesTabBar];
    

    相关文章

      网友评论

          本文标题:[ iOS 开发] LRFactory 之 LRVCExtend

          本文链接:https://www.haomeiwen.com/subject/jirxghtx.html