MHUIKIT MHUIKIT 是一套 iOS 开发 UI 框架,只要继承了基础类,就能轻松布局页面。实现了网络、UI、逻辑的分层。每个 VC 配置了一个 dataConstructor,用作网络请求。每个 VC 都有一个 tableView。在 dataConstructor 中进行网络请求,配置 tableView 的 cell 信息,实现 UI 布局的目的。
控制器层:MHTableViewController 新建的 VC 继承自 MHTableViewController,初始化 dataConstructor
- (void) constructData { if (_dataConstructor == nil) { _dataConstructor = [[HomeDataConstructor alloc] init]; _dataConstructor.viewControllerDelegate = self; _dataConstructor.delegate = self; } // 初始化完毕 发送网络请求 [self.dataConstructor loadData];
} 在网络回调中刷新 tableView(每个 VC 都有一个 tableView)。
- (void) networkDataContructor:(MHNetworkDataConstructor *)dataConstructor didFinishWithData:(id)data { //刷新数据 [self.dataConstructor constructData]; self.adaptor.items = self.dataConstructor.items; self.adaptor.arrayKeys = self.dataConstructor.arrayKeys; self.adaptor.headerModels = self.dataConstructor.headerModels; self.adaptor.footerModels = self.dataConstructor.footerModels; [self.uiTableView reloadData]; }
事件 :
- (void) tableView:(UITableView *)tableView didSelectObject:(id)object rowAtIndexPath:(NSIndexPath *)indexPath { NSString *cellType = object.cellType;
if ([cellType isEqualToString:@"cell.type.block"]) { //do sth } }
网络层:新建类继承自 MHNetworkDataConstructor :
-
(void)loadData { //请求接口,在回包中调用 VC 中的代理方法。调用 constructData 方法,刷新页面。 }
-
(void)constructData { [self.items removeAllObjects]; MHTitleDataModel *model = [MHTitleDataModel new]; model.content = @"cell.type.block"; model.cellClass = [MHTitleTableViewCell class]; model.cellType = @"cell.type.block"; model.cellHeight = @([MHTitleTableViewCell heightForCell]); model.delegate = self.viewControllerDelegate; model.showTopLine = YES; model.topLineColor = COLOR_GRAY; model.selectedStyle = UITableViewCellSelectionStyleGray; [self.items addObject:model];
//配置 cell 信息 }
MHAppSchemaObserver 和 H5 交互的类:可以在 APP 启动时初始化一个单例,在该单例中注册协议。
MHAppSchemaObserver* observers = [MHAppSchemaObserver sharedInstance]; //nlogin 为公共参数,可为多个,按顺序执行。 [observers addPublicParamName:@"nlogin" invoke:^(NSString *paramName, NSString *paramValue, UIViewController *viewController, void(^callback)(BOOL complete) ) { //name 协议的名字,parameters 参数,viewController 当前控制器 LockViewController *lockVC = [LockViewController new];
UINavigationController *naVC = [UIApplication dd_rootNavigationController ];
WEAK(lockVC); lockVC.completion = ^(BOOL success, id info) { if (success) {
[weaklockVC dismissViewControllerAnimated:YES completion:nil]; callback(YES); } else {
callback(NO); } }; [naVC presentViewController:lockVC animated:YES completion:nil];
}]; //单个协议 [observers addObserverName:@"service.task.deviceInfo" serviceName:@"/deviceInfo" invoke:^id (NSString *name, NSDictionary *parameters, UIViewController *viewController) { //name 协议的名字,parameters 参数,viewController 当前控制器 return nil; }]; //h5 调用 href="mhuikit://Service/deviceInfo?nloin=y" 会先执行 nlogin 的 block, callback(YES) 时继续调用 deviceInfo 的 block,达到 OC 和 H5 交互。OC 也可以调用 NSURL *url = [NSURL URLWithString:@"mhuikit://Service/deviceInfo?nlogin=y" ]; [[MHAppSchemaObserver sharedInstance] openURL:url];达到同样的目的。