这几天,需要重构下部分代码,这里简要记录下.但是涉及的技术要点还是很多,所以分为多个篇章叙述.此教程来源于,并将于应用于实践,不做过多的概念性阐释和争论.每个篇章都会附上实际的可执行的代码.因涉及的技术点,有许多探索的部分,暂定每两天更新一个篇章.欢迎广大iOS同行,批评指正!
教程内容,按更新顺序排序
- : 结合实际的例子,提出并应用一种从MVC迁移到MVVM的可行性方案.
- : 此处会结合RestKit,提出并制作一个可直接应用于代码的网络请求实现方案,支持自动翻页,自动配置URL与数据模型的关联关系等.
- : 会涉及到使用Leancloud做服务器端,使用marddown库解析markdwon内容,一个更加实际的MVVM各技术细节的具体实现技巧.
定义良好的接口,是成功的第一步!
//// YFMVVMDelegate.h// iOS122//// Created by 颜风 on 15/10/13.// Copyright (c) 2015年 iOS122. All rights reserved.//#import@protocol YFMVVMRequestDelegate;/** * MVVM协议,用于规定MVVM模式的基本约定. * * 常用于约定"V",此处的V,指的是视图的载体,或者是连接点.可以是一个View,也可以是一个控制器,或者任意NSObject对象. */@protocol YFMVVMDelegate @required@property (nonatomic, strong) id model; //!< 数据模型,用于表示从外部传入的数据.@property (nonatomic, strong, readonly) id viewModel; //!< 数据模型,用于表示直接在视图上显示的数据模型.@optional@property (nonatomic, strong) id request; //!< 网络请求.用于联网动态更新数据.@end/** * 用于规定MVVM中的request网络请求的协议. */@protocol YFMVVMRequestDelegate @required/** * 获取数据. * * @param component MVVM组件中的V部分,可以是一个View,也可以是一个控制器,或者任意NSObject对象. * @param success 请求成功时的回调.会把视图模型回调出去. * @param failure 请求失败时的回调.会把错误信息回调出去. */-(void) get: (id ) component success: (void (^)(id))success failure:(void (^)(NSError *))failure;@optional/** * 重置页码,从头刷新. * * 下次调用 get:success:failure 方法时,会获取最新的数据. */-(void) reset;/** * 移动到下一页. * * 下次调用 get:success:failure 方法时,会获取下一页的数据. */-(void) nextPage;@end