内容简介:在项目中我们可能都需要判断断网的情况,然后进行一下提示,或者我们需要在每个控制器中都需要初始一些东西,那么我们可以在项目中用一个基类去做这些事情,可是,如果我们的项目想要后面添加这些东西,我们再去用基类,改起来就比较麻烦了,或者可能改出问题来。这时候我们可能会用到拦截器来进行一些操作。下面是我用拦截器来进行一些网络的提示,如图。我对这些东西做了一些封装,让我们看一下来如何使用它。
在项目中我们可能都需要判断断网的情况,然后进行一下提示,或者我们需要在每个控制器中都需要初始一些东西,那么我们可以在项目中用一个基类去做这些事情,可是,如果我们的项目想要后面添加这些东西,我们再去用基类,改起来就比较麻烦了,或者可能改出问题来。这时候我们可能会用到拦截器来进行一些操作。下面是我用拦截器来进行一些网络的提示,如图。
我对这些东西做了一些封装,让我们看一下来如何使用它。
1、导入头文件 #import "ZYInterceptorWithNetwork.h"
2、在需要使用的地方写入下面的代码
ZYInterceptorWithNetwork *network = [ZYInterceptorWithNetwork sharedInstance]; network.promptStr = @"网络有错"; //网络提示内容 network.btnText = @"确定";//网络提示按钮文字 network.title = @"提示";//标题 [network loadInterceptorWithActionName:@"viewWillAppear:" optionType:AspectPositionAfter error:^(NSError *interceptorError) { NSLog(@"拦截错误"); }];//拦截代码
3、假如有的地方我们不需要拦截,那么我们可以这么做
1)、导入头文件 #import "ZYInterceptorWithNetwork.h"
2)、 跳转界面的地方写入下面的代码
ZYThreeViewController *three= [[ZYThreeViewController alloc] init]; three.isDisabledInterceptor = YES; //跳转的地方设置失去作用 [self.navigationController pushViewController:three animated:YES];
这就是基本的用法。当然,我们也可以去扩充这些东西,我只是做了网络的操作,我们也可以去做别的一些操作,只要在下面这个方法中修改一些东西即可:
// 通过这种方式可以代替原来框架中的基类,不必每个 ViewController 再去继续原框架的基类 #pragma mark - alternative methods - (void)action:(BOOL)animated viewController:(UIViewController *)viewController { if (!viewController.isInitTheme) { // 去做基础业务相关的内容 viewController.isInitTheme = YES; } if (![ZYInterceptorWithNetwork isConnectionAvailableWithStatus:nil]) { //设置提示框或者什么操作 UIViewController *currentVc = [self getCurrentController]; if (self.promptStr.length != 0 && self.title.length != 0 && self.btnText.length != 0 ) { UIAlertController *alertVc = [UIAlertController alertControllerWithTitle:_title message:_promptStr preferredStyle:UIAlertControllerStyleAlert]; UIAlertAction *sureBtn = [UIAlertAction actionWithTitle:_btnText style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) { }]; [alertVc addAction:sureBtn]; [currentVc presentViewController:alertVc animated:YES completion:nil]; }else { UIAlertController *alertVc = [UIAlertController alertControllerWithTitle:@"提示" message:@"网络状况不太好,请检查网络..." preferredStyle:UIAlertControllerStyleAlert]; UIAlertAction *sureBtn = [UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) { }]; [alertVc addAction:sureBtn]; [currentVc presentViewController:alertVc animated:YES completion:nil]; } } }
大概就这些步骤了,如有需要可以下载: https://github.com/zhangyqyx/Interceptor
希望大家能提出宝贵的意见,可以给我留言,也可以发邮件到我的邮箱: namezyqyx@163.com
谢谢大家,如果你有更好的想法或文章请告知,不胜感激。
作者:谁遇而安
链接:https://www.jianshu.com/p/fa5a18723174
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 前端架构之vue+axios 前端实现登录拦截(路由拦截、http拦截)
- react离开页面,自定义弹框拦截,路由拦截
- Springboot整合Hibernate拦截器时无法向拦截器注入Bean
- 基于原生fetch封装一个带有拦截器功能的fetch,类似axios的拦截器
- SpringMVC拦截器
- angular 拦截器
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。