MHUIKIT 0.8.5

MHUIKIT 0.8.5

walker 维护。



MHUIKIT 0.8.5

  • zhaomh

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];达到同样的目的。