前言
很多的app使用MVC设计模式来将“用户交互”与“数据和逻辑”分开,而model其中一个重要作用就是持久化。下文中设计的Model可能不是一个完美的,扩展性强的model范例,但在我需要重构的app中,这样的设计能够满足我的需要。
关于Model
Model层包含了app的数据与逻辑,Model层中的类需要关心的是数据的表现,存储,以及操作。Model层是整个app生态中相对独立的一个部分,因为它不会直接与controller层或者是View层进行通讯,而是在其他层需要请求它的信息的时候进行间接通讯。
Model有什么用?
想要写好一个model,首先要清晰Model的作用。
-
属性存取:将文件中的一些特性和数据以属性的形式存储
-
可变性:属性可以readwrite,所以能够被改变,并保存到本地
-
KVO:可以观察一个属性的值并在它改变的时候受到通知,并以此对UI或其他地方进行控制
-
处理数据:根据业务逻辑处理网络获取数据与本地存储数据
如何定义Model类
我们可以创建一系列的Model类,它们之间可以互相继承,同时每一个Model类是与当前app中的实体对应。比如在我当前需要重构的app中,用户数据对应的是UserInformationModel,班级信息对应的是StudentClassModel。
另一方面,在Model类的实现过程中,有许多问题需要解决,所以我下面会根据我当前正在重构的app的一些情况结合来解释。
信息的存储格式处理
数据可以以各种不同的格式储存,在我重构的app中,数据等信息是使用普通的数据结构来存放,比如使用数据或者是字典来保存Model的信息。在一开始建立Model的时候并没有太大的问题,但是当需求不断增加,一个Model类的信息开始变得庞大起来的时候,问题就开始浮现了。比如下面我要输出用户的姓名、年龄、班级、班主任、年级等数据。
// never do this !!!
- (void)printInformation
{
NSLog(@"name: %@", [user objectForKey:@"name"]);
NSLog(@"age: %@"m [user objectForKey:@"age"]);
NSLog(@"class: %@"m [user objectForKey:@"clazz"