[iOS基础控件 - 4.2] 字典转模型Model

A.使用字典加载数据的缺点

1.用户自行指定key,容易出错

2.存入、取出都需要key,容易混乱

B.模型 (MVC中的model)

1.字典与模型对比:

(1)字典:存储数据,通过字符串类型的key取值(容易写错,写错了key编译器不会报错)

(2)模型:存储数据,自定义属性存储数据,其实就类似JavaBean,本质是数据封装

2.实现

(1)定义模型类

 1 @interface App : NSObject
 2
 3 /**
 4  copy : NSString
 5  strong: 一般对象
 6  weak: UI控件
 7  assign: 基本数据类型
 8  */
 9
10 /**
11  名称
12  */
13 @property(nonatomic, copy) NSString *name;
14
15 /**
16  图标
17  */
18 @property(nonatomic, copy) NSString *icon;
19 @end

(2)使用模型读取存储、读取数据

存储:

 1 #pragma mark 取得应用列表
 2 - (NSArray *) apps {
 3     if (nil == _apps) {
 4         // 1.获得plist的全路径
 5         NSString *path = [[NSBundle mainBundle] pathForResource:@"app.plist" ofType:nil];
 6
 7         // 2.加载数据
 8         NSArray *dictArray  = [NSArray arrayWithContentsOfFile:path];
 9
10         // 3.将dictArray里面的所有字典转成模型,放到新数组中
11         NSMutableArray *appArray = [NSMutableArray array];
12         for (NSDictionary *dict in dictArray) {
13             // 3.1创建模型对象
14             App *app = [[App alloc] init];
15
16             // 3.2 将字典的所有属性赋值给模型
17             app.name = dict[NAME_KEY];
18             app.icon = dict[ICON_KEY];
19
20             // 3.3 添加到app数组中
21             [appArray addObject:app];
22         }
23
24         _apps = appArray;
25     }
26
27     return _apps;
28 }

读取:

1         iconView.image = [UIImage imageNamed:appData.icon];
2         [appView addSubview:iconView];
3
4         // 2.设置APP名字
5         UILabel  *nameLabel = [[UILabel alloc] init];
6         nameLabel.text = appData.name;

C.Model改进

在ViewControl中解析、存储数据, 增加了数据、类的耦合性,控制器关心太多,在Model被修改之后难以进行自我修改.

解决 : ==> 所以在Model中解析数据

1.实现

(1)自定义带数据参数的构造方法

声明:

1 /**
2  自定义构造方法
3  通过字典来初始化模型对象
4  */
5 - (id) initWithDictionary:(NSDictionary *) dictionary;

实现:

1 - (id) initWithDictionary:(NSDictionary *) dictionary {
2     if (self = [super init]) {
3         self.name = dictionary[NAME_KEY];
4         self.icon = dictionary[ICON_KEY];
5     }
6
7     return self;
8 }

使用:

1             // 3.1创建模型对象
2             App *app = [[App alloc] initWithDictionary:dict];
3
4             // 3.2 添加到app数组中
5             [appArray addObject:app];

(2)进一步提供类方法

1 + (id) appWithDictionary:(NSDictionary *) dictionary {
2     // 使用self代表类名代替真实类名,防止子类调用出错
3     return [[self alloc] initWithDictionary:dictionary];
4 }

D.使用”instancetype”代替”id"

id: 代指所有类型,但是使用不恰当的类型指针指向不匹配的对象时,编译器不会报错、警告,但在运行时很可能会出错

instantcetype:编译器能够根据当前指向的对象,自动检查变量类型是否正确,进而发出警告

时间: 2024-12-17 22:25:57

[iOS基础控件 - 4.2] 字典转模型Model的相关文章

[iOS基础控件 - 6.4] 汽车品牌展示 Model嵌套/KVC/TableView索引

A.需求 1.使用汽车品牌名称头字母为一个Model,汽车品牌为一个Model,头字母Model嵌套品牌Model 2.使用KVC进行Model封装赋值 3.展示头字母标题 4.展示索引(使用KVC代替遍历取出所有索引值) B.实现 1.Model嵌套 其实就是将另一个Model作为成员 .plist 文件结构 GroupCar中有存储Car的数组 1 @property(nonatomic, strong) NSArray *cars; 封装Model的时候需要进行相应处理 CarGroup.

[iOS基础控件 - 5.5] 代理设计模式 (基于”APP列表"练习)

A.概述 在"[iOS基础控件 - 4.4] APP列表 进一步封装,初见MVC模式”上进一步改进,给“下载”按钮加上效果.功能 1.按钮点击后,显示为“已下载”,并且不可以再按 2.在屏幕中间弹出一个消息框,通知消息“xx已经被安装”,慢慢消失 3.消息框样式为圆角半透明 B.不使用代理模式,使用app空间组和主View之间的父子View关系 1.在主View中创建一个消息框 主View控制器:ViewController.m 1 // 创建下载成功消息框 2 CGFloat labelWid

iOS基础控件UINavigationController中的传值

iOS基础控件UINavigationController中的传值,代理传值,正向传值,反向传值 #import <UIKit/UIKit.h> //声明一个协议 @protocol SendValue<NSObject> //定义一个方法 - (void)sendBtnTitle:(NSString *)title; @end @interface FirstViewController : UIViewController // 定义代理 @property (nonatomi

ios基础控件之开关按钮(UISwitch)

UISwitch控件是iOS开发的基础控件,是非常简单的一个控件,因为它的方法比较少.UISwitch继承于UIControl基类,因此可以当成活动控件使用. 注意:开关状态通过它的on属性进行读取,该属性是一个BOOL属性 创建: UISwitch* mySwitch = [[ UISwitch alloc]initWithFrame:CGRectMake(0.150.0f,100.0f,0.0f,0.0f)]; 可能你会疑问为什么它的大小都设置为0?没错,它的大小你设置是无效的,系统会为你分

iOS 基础控件(下)

上篇介绍了UIButton.UILabel.UIImageView和UITextField,这篇就简短一点介绍UIScrollView和UIAlertView. UIScrollView 顾名思义也知道这个是和滚动相关的控件,在Android开发时遇到过ScrollView,当内容的尺寸超出了屏幕范围之后,用ScrollView则可以通过滚动的方式使得超出屏幕的那部分内容通过滚动的方式显示出来,在Android里面有水平的ScrollView和垂直的ScrollView,在iOS里面就只有一个S

[iOS基础控件 - 6.11.3] 私人通讯录Demo 控制器的数据传递、存储

A.需求 1.搭建一个“私人通讯录”Demo 2.模拟登陆界面 账号 密码 记住密码开关 自动登陆开关 登陆按钮 3.退出注销 4.增删改查 5.恢复数据(取消修改) B.基本架构 1. 5个控制器 (1)导航控制器 NavigationController (2)登陆 UIViewController 输入账号密码 记住密码.自动登录开关 登陆跳转按钮 (3)联系人列表 TableViewController 注销功能 添加联系人跳转按钮 (4)添加联系人 UIView (5)查看.编辑 UI

[iOS基础控件 - 4.4] 进一步封装&quot;APP列表&rdquo;,初见MVC模式

A.从ViewController分离View 之前的代码中,View的数据加载逻辑放在了总的ViewController中,增加了耦合性,应该对控制器ViewController隐藏数据加载到View的细节. 封装View的创建逻辑 封装View的数据加载逻辑到自定义的UIView中 B.思路 使用xib封装自定义view的步骤: 1.新建一个继承UIView的自定义view,这里的名字是"AppView",用来封装独立控件组 每个AppView封装了如下图的控件组 2.新建一个xi

[iOS基础控件 - 6.9] 聊天界面Demo

A.需求 做出一个类似于QQ.微信的聊天界面 1.每个cell包含发送时间.发送人(头像).发送信息 2.使用对方头像放在左边,我方头像在右边 3.对方信息使用白色背景对话框,我方信息使用蓝色背景对话框 4.隐藏相同的发送时间 5.底部功能按钮:语音按钮.消息输入框.表情按钮.附加按钮 6.响应键盘事件,呼出键盘.隐藏键盘时对上述的视图作出上移操作 7.键盘的发送事件处理 B.实现点 1.底层视图搭建 上部分聊天信息框:UITableView 下部分功能区:UIButton 信息输入框使用无边框

[iOS基础控件 - 6.7.1] 微博展示 代码

Controller: 1 // 2 // ViewController.m 3 // Weibo 4 // 5 // Created by hellovoidworld on 14/12/4. 6 // Copyright (c) 2014年 hellovoidworld. All rights reserved. 7 // 8 9 #import "ViewController.h" 10 #import "Weibo.h" 11 #import "W