[ iOS 开发] LRFactory 之 LRVCExtend

2020-04-30  本文已影响0人  leoRR

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];
上一篇下一篇

猜你喜欢

热点阅读