iOS开发UI篇—使用嵌套模型完成的一个简单汽车图标展示程序

一、plist文件和项目结构图


说明:这是一个嵌套模型的示例

二、代码示例:

YYcarsgroup.h文件代码:

 1 //  2 // YYcarsgroup.h
 3 // 07-汽车展示(高级)
 4 //  5 // Created by apple on 14-5-28.
 6 // Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8  9 #import <Foundation/Foundation.h>
10 11 @interface YYcarsgroup : NSObject
12 @property(nonatomic,copy)NSString *title;
13 @property(nonatomic,strong)NSArray *cars;
14 15 -(instancetype)initWithDict:(NSDictionary *)dict;
16 +(instancetype)carsgroupWithDict:(NSDictionary *)dict;
17 @end


YYcarsgroup.m文件代码:

 1 //  2 // YYcarsgroup.m
 3 // 07-汽车展示(高级)
 4 //  5 // Created by apple on 14-5-28.
 6 // Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8  9 #import "YYcarsgroup.h" 10 #import "YYcars.h" 11 12 @implementation YYcarsgroup
13 -(instancetype)initWithDict:(NSDictionary *)dict
14 {
15 if (self=[super init]) {
16 //嵌套的字典转模型 17 self.title=dict[@"title"];
18 19 //注意 20 NSArray *dictcars=dict[@"cars"];
21 //像下面这样写可以提高性能 22 NSMutableArray *arrayM=[NSMutableArray arrayWithCapacity:dictcars.count];
23 for (NSDictionary *dict in dictcars) {
24 YYcars *yycars=[[YYcars alloc]initWithDict:dict];
25  [arrayM addObject:yycars];
26  }
27 // 赋值存储模型的数组给属性 28 self.cars=arrayM;
29  }
30 return self;
31 }
32 33 +(instancetype)carsgroupWithDict:(NSDictionary *)dict
34 {
35 return [[self alloc]initWithDict:dict];
36 }
37 @end


YYcars.h文件

 1 //  2 // YYcars.h
 3 // 07-汽车展示(高级)
 4 //  5 // Created by apple on 14-5-28.
 6 // Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8  9 #import <Foundation/Foundation.h>
10 11 @interface YYcars : NSObject
12 @property(nonatomic,copy)NSString *name;
13 @property(nonatomic,copy)NSString *icon;
14 15 -(instancetype)initWithDict:(NSDictionary *)dict;
16 +(instancetype)carsWithDict:(NSDictionary *)dict;
17 @end


YYcars.m文件

 1 //  2 // YYcars.m
 3 // 07-汽车展示(高级)
 4 //  5 // Created by apple on 14-5-28.
 6 // Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8  9 #import "YYcars.h" 10 11 @implementation YYcars
12 13 -(instancetype)initWithDict:(NSDictionary *)dict
14 {
15 if (self=[super init]) {
16 self.name=dict[@"name"];
17 self.icon=dict[@"icon"];
18  }
19 return self;
20 }
21 +(instancetype)carsWithDict:(NSDictionary *)dict
22 {
23 return [[self alloc]initWithDict:dict];
24 }
25 @end


YYViewController.m文件

 1 //  2 // YYViewController.m
 3 // 07-汽车展示(高级)
 4 //  5 // Created by apple on 14-5-28.
 6 // Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8  9 #import "YYViewController.h"  10 #import "YYcarsgroup.h"  11 #import "YYcars.h"  12  13 @interface YYViewController ()<UITableViewDataSource>
 14 @property (strong, nonatomic) IBOutlet UITableView *tableview;
 15 @property(nonatomic,strong) NSArray *car;
 16 @end  17  18 @implementation YYViewController
 19  20 - (void)viewDidLoad
 21 {
 22  [super viewDidLoad];
 23  24 self.tableview.rowHeight=60.f;
 25 self.tableview.dataSource=self;
 26 NSLog(@"%d",self.car.count);
 27 }
 28 #pragma mark- 实现懒加载
 29 //1.从包中读取数据
 30 //2.字典转模型
 31 //3.返回cars  32 -(NSArray *)car
 33 {
 34 if (_car==nil) {
 35  36 NSString *fullpath= [[NSBundle mainBundle]pathForResource:@"cars_total.plist" ofType:nil];
 37 NSArray *arrayM=[NSArray arrayWithContentsOfFile:fullpath];
 38  39 NSMutableArray *carsarray=[NSMutableArray array];
 40 for (NSDictionary *dict in arrayM) {
 41 YYcarsgroup *carsgroup=[YYcarsgroup carsgroupWithDict:dict];
 42  [carsarray addObject:carsgroup];
 43  }
 44 _car=[carsarray copy];
 45  }
 46 return _car;
 47 }
 48  49  50 #pragma mark- 实现tableview的数据展示
 51 //1.设置数据源,遵守协议
 52 //2.返回组
 53 //3.返回行
 54 //4.每组每行对应的数据
 55 //4.1去缓存中去取cell
 56 //4.2若没有,则创建cell,并盖章
 57 //4.3设置cell的数据
 58 //4.4返回cell  59  60 -(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
 61 {
 62 return self.car.count;
 63 }
 64 -(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
 65 {
 66 YYcarsgroup *carsgroup=self.car[section];
 67 return carsgroup.cars.count;
 68 }
 69 -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
 70 {
 71 static NSString *identifier=@"car";
 72 //4.1去缓存中去取cell  73 UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:identifier];
 74 //4.2若没有,则创建cell,并盖章  75 if (cell==nil) {
 76 cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier];
 77  }
 78 //4.3设置cell的数据
 79 //设置对应的组  80 YYcarsgroup *carsgroup=self.car[indexPath.section];
 81 //设置对应的行  82 YYcars *yycars=carsgroup.cars[indexPath.row];
 83  84 cell.imageView.image=[UIImage imageNamed:yycars.icon];
 85 cell.textLabel.text=yycars.name;
 86 //4.4返回cell  87 return cell;
 88 }
 89  90 //设置每组的标题  91 -(NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
 92 {
 93 YYcarsgroup *carsgroup=self.car[section];
 94 return carsgroup.title;
 95 }
 96  97 //设置索引  98 -(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView
 99 {
100 //利用kvc取出所有的标题 101 NSArray *title=[self.car valueForKeyPath:@"title"];
102 return title;
103 }
104 105 //隐藏状态栏 106 -(BOOL)prefersStatusBarHidden
107 {
108 return YES;
109 }
110 @end


实现效果:


三、注意点

1.设置索引

代码如下:

//设置索引
-(NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView
{
 //利用kvc取出所有的标题
 NSArray *title=[self.car valueForKeyPath:@"title"];
 return title;
}


2.cell的性能优化

代码如下:

 static NSString *identifier=@"car";
 //4.1去缓存中去取cell
 UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:identifier];
 //4.2若没有,则创建cell,并盖章 if (cell==nil) {
 cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier];
 }


请注意:cell内部数据处理的细节。(如何节省内存?)

时间: 2024-09-20 06:00:56

iOS开发UI篇—使用嵌套模型完成的一个简单汽车图标展示程序的相关文章

iOS开发UI篇—使用xib自定义UItableviewcell实现一个简单的团购应用界面布局

一.项目文件结构和plist文件 二.实现效果 三.代码示例 1.没有使用配套的类,而是直接使用xib文件控件tag值操作 数据模型部分: YYtg.h文件 1 // 2 // YYtg.h 3 // 01-团购数据显示(没有配套的类) 4 // 5 // Created by apple on 14-5-29. 6 // Copyright (c) 2014年 itcase. All rights reserved. 7 // 8 9 #import <Foundation/Foundatio

iOS开发UI篇—字典转模型

一.能完成功能的"问题代码" 1.从plist中加载的数据 2.实现的代码 // // LFViewController.m // 03-应用管理 // // Created by apple on 14-5-22. // Copyright (c) 2014年 heima. All rights reserved. // #import "LFViewController.h" @interface LFViewController () @property (n

iOS开发UI篇—UITableviewcell的性能优化和缓存机制

iOS开发UI篇-UITableviewcell的性能问题 一.UITableviewcell的一些介绍 UITableView的每一行都是一个UITableViewCell,通过dataSource的 tableView:cellForRowAtIndexPath:方法来初始化每⼀行 UITableViewCell内部有个默认的子视图:contentView,contentView是UITableViewCell所显示内容的父视图,可显示一些辅助指示视图 辅助指示视图的作⽤是显示一个表示动作的

iOS开发UI篇—popoverController使用注意

iOS开发UI篇-popoverController使用注意 iOS开发UI篇-popoverController使用注意 一.设置尺寸 提示:不建议,像下面这样吧popover的宽度和高度写死. 1 //1.新建一个内容控制器 2 YYMenuViewController *menuVc=[[YYMenuViewController alloc]init]; 3 4 //2.新建一个popoverController,并设置其内容控制器 5 self.popover=[[UIPopoverCo

iOS开发UI篇:APP主流UI框架结构

一.简单示例 说明:使用APP主流UI框架结构完成简单的界面搭建 搭建页面效果: 开发UI篇:APP主流UI框架结构-"> 查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/OS/extra/

iOS开发UI篇—xib的简单使用实例_IOS

这个博客申请了有一段时间了,觉得好像是该写点什么了.这篇文章主要是关于一些xib的简单的用法,希望可以帮助到刚刚使用xib的新手们. 什么是xib? xib能做什么? 用来描述软件界面的文件. 如果没有xib,所有的界面都需要通过代码来手动创建. 有了xib以后,可以在xib中进行可视化开发,然后加载xib文件的时候,系统自动生成对应的代码来创建界面. 与xib类似的还有storyboard文件.xib和storyboard的比较,一个轻量级一个重量级. 共同点: 都用来描述软件界面.都用Int

iOS开发UI篇—iPad和iPhone开发的比较

一.iPad简介 1.什么是iPad 一款苹果公司于2010年发布的平板电脑 定位介于苹果的智能手机iPhone和笔记本电脑产品之间 跟iPhone一样,搭载的是iOS操作系统 2.iPad的市场情况 截止至2013年10月23日,iPad已经累计销售1.7亿台 在平板市场的占有率高达81% 二.关于iphone和iPad 说明:iPhone是手机,iPad.iPad Mini是平板电脑 iPhone和iPad开发的区别 屏幕的尺寸 \分辨率 UI元素的排布 \设计 键盘 API 屏幕方向的支持

iOS开发UI篇—UIWindow简单介绍

一.简单介绍 UIWindow是一种特殊的UIView,通常在一个app中只会有一个UIWindow iOS程序启动完毕后,创建的第一个视图控件就是UIWindow,接着创建控制器的view,最后将控制器的view添加到UIWindow上,于是控制器的view就显示在屏幕上了 一个iOS程序之所以能显示到屏幕上,完全是因为它有UIWindow.也就说,没有UIWindow,就看不见任何UI界面 补充:UIWindow是创建的第一个视图控件(创建的第一个对象是UIapplication)如下图:

iOS开发UI篇—Quartz2D简单介绍

一.什么是Quartz2D Quartz 2D是⼀个二维绘图引擎,同时支持iOS和Mac系统 Quartz 2D能完成的工作: 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成图片(图像) 读取\生成PDF 截图\裁剪图片 自定义UI控件 二.Quartz2D在iOS开发中的价值 为了便于搭建美观的UI界面,iOS提供了UIKit框架,⾥⾯有各种各样的UI控件 UILabel:显⽰文字 UIImageView:显示图片 UIButton:同时显示图片和⽂字(能点击) 利⽤UIKi