码迷,mamicode.com
首页 > 其他好文 > 详细

Objective-c——UI基础开发第六天(UITableView)

时间:2016-04-01 13:06:33      阅读:397      评论:0      收藏:0      [点我收藏+]

标签:

一、UITableView的简单使用

显示要素:

  1、显示多少给区组

  2、显示多少行数据

  3、每行显示什么内容

代理不会提醒你有什么方法没调用,但是UITableViewDataSource会

 

1)用代码创建一个UITableView

UITableView *tableview =[[UITableView alloc]initWithFrame:CGRectMakr(0,0,[UIScreen mainScreen].bounds.size.width,[UIScreen mainScreen].bounds.size.height) style:UITableViewStylePlain];

/**

注意 style:

UITableViewStylePlain  

UITableViewStyleGrouped

区别:plain 的footer 和 header 具有浮动效果,并且中间没有间隔

grouped:footer和header之间具有一定的间距

*/

 

2)设置tableview datasource的代理方法 

tableview.datasource =self;

 

3)调用三个一定要实现的代理方法

  3.1) numberOfSectionsInTableView 返回(NSInteger)

  3.2) numberOfRowsInSection 返回(NSInteger)

  3.3)cellForRowsAtIndex 返回(UITableViewCell*)

 

4)注意 三个代理方法的调用方式(当你设置3个section 分别显示1,2,2行row 的时候)

技术分享

可以观测到:

调用section组数次numberOfSectionsInTableView方法

每次都会确认全部组对应的相应行数 调用numberOfRowsInSection

sections*rows

调用sections*rows次cellForRowsAtIndex方法

把对应每组每行都取过去

 

5)总结调用代理方法的过程和次数:

每次先调用获取总共的组数,然后传入组数,获取第一组的行数,再传入组数,获取第二组的行数,以此类推,最后,根据每组对应的每行 indexPath 属性进行内容传递

 

6)设置tableview section的header和footer

titleForFooterInSection/titleForHeaderInsection 返回(NSString*)

注意也可以用viewForFooterInSection/viewForHeaderInSection 不同的是,需要定义(UITableViewDelegate)这个代理,返回(UIView*)

直接返回就可显示

 

二、汽车展示:UITableView的数据绑定

1)创建model类

@property(nonatomic,copy)NSString *name;

@property(nonatomic,copy)NSString *icon;

-(instancetype)initWithDictionary:(NSDictionary*)dict;

+(instancetype) CarinitWithDictioary:(NSDictionary*)dict;

2)定义执行model类方法

-(instancetype) initWithDictionary:(NSDictionary*)dict

{//注意,之前错写成 Carmodel .init   报错不能初始化一个类NSObject

if(self =[super init])

{ [self setValuesForKeyWithDictionary:dict];}}

+(instancetype)CarinitWithDictionary:(NSDictionary*)dict{[return [self alloc]initWithDictionary:dict];}

3)进行懒加载,懒加载实际上就是重定义它的getter方法,而且可以在使用的时候分配内存,不使用的时候自动回收内存,节省内存消耗,并且可以避免重复实例化,各实例之间独立,同时也能够减少直接在viewDidLoad中定义参数的代码量

@property (nonatomic,strong) NSArray *dataArray;(如果将来会修改dataArray的值时,需要用NSMutableArray 才可以调用相应的赋值方法 addObjects..)

-(NSArray *) dataArray

{

NSString *path=[NSBundel mainBundel] pathForResourct :@"car.plist",ofType:nil];

NSArray *tempArray =[NSArray arrayWithContentsOfFile :path];

NSMutableArray *muArray =[NSMutableArray array];

for(NSDictionary *dict in tempArray)

{

CarModel *model =[CarModel CarinitWithDictionary:dict];

[muArray addObject:model]; 

}

_dataArray =muArray;

return _dataArray;

}

注意,

如果tableview中没有显示的时候,可以考虑:

  1、是否添加代理 tableview.delegate=self;

  2、考虑是否取出数据:path路径是否正确,懒加载是否成功?

 

三、一些其他的tableview 和tableviewcell 的属性

1)/* 

     cell.accessoryType=UITableViewCellAccessoryDisclosureIndicator; //箭头

     cell.accessoryType=UITableViewCellAccessoryNone; //没有箭头

     cell.accessoryType =UITableViewCellAccessoryCheckmark; //打勾

     cell.accessoryType=UITableViewCellAccessoryDetailButton;//圆圈+i

     */

 

 /*

     cell.selectionStyle=UITableViewCellSelectionStyleBlue;//ios7以上默认为灰色

     cell.selectionStyle=UITableViewCellSelectionStyleGray;

     cell.selectionStyle=UITableViewCellSelectionStyleNone;//什么都不显示

     cell.selectionStyle=UITableViewCellSelectionStyleDefault;//默认为灰色

     

     cell.selectedBackgroundView设置背景view 但是不能改变宽高

     */

 

/**

 tableview 的常见属性

 1、rowHeight 行高

 2、separatorColor 分割线颜色

 3、separatorStyle 分割线样式

 4、allowMultipleSelection 是否允许多行选择

 */

/**

 cell的常见属性

 1、selectionStyle

 2、selectedBackgroundView 注意 view宽高是可以改变,但是相对位置无法改变

 3、background 注意其backgroundview不设置frame 默认就是完整的一行宽高,即便改变,宽高的设置仍然是无效的

 */

/**

 cell的内置控件

 1、textLabel

 2、detailLabel

 3、imageview

 4、accessoryType

 5、accessoryView

 */

/**

 UITableViewCellStyle

 UITableViewCellStyleDefault

 UITableViewCellStyleValue1

 UITableViewCellStyleValue2

 UITableViewCellStyleSubtitle

 */

/**

 accessoryType

 UITableViewCellAccessoryDetailDisclosureIndicator

 UITableViewCellAccessorycheckwork

 */

/**

 tableview.separatorStyle

 UITableViewCellSeparatorStyleNone

 UITableViewCellSepatratorStyleSingleLine

 UITableViewCellSeparatorStyleSingleLineEtched

 */

/**

 设置cell的选择样式

 UITableViewCellSelectionsStyleNone

 UITableViewCellSelectionsStyleGray

 UITableViewCellSelectionsStyleDefault

 UITableViewCellSelectionsStyleBlue

 */

2)注意为什么在tableview的section中加入了footer/header但是没有显示

如果直接控件拖拽UITableView 的话会产生一个默认的section高度

但是如果是代码添加的话,就需要手动设置:
tableview.sectionFooterHeight=20;

tableview.SectionHeaderHeight =20;

 自定义accessoryview的时候,frame中的坐标值不能改变,只能改变其宽高

类似switch 的宽textfield的高 是不能修改的

3)设置tableview的行高有两种方式

  a、tableview.rowHeight =5;

  b  heightForRowAtIndexPath(UITableViewDelegate) 返回NSFloat

  唯一的区别是,用执行方法,可以获取indexpath 可以针对不同的行设置会变动的行高

 

四、cell的重用

1)了解为什么要重用cell

cell的浏览机制是,当用户滑动时,划出窗口的cell就会被废弃,然后进入的是一个重新创建好的cell,这样的话,一旦运行时间过长,不断的废弃重创, 会造成程序内存吃紧,效率非常低 隐患很大。每个cell小时之后,都会重新创建cell

cell重用机制:把移出的cell 放入缓存池,重复使用,而只是更换上面的数据

那么,当有多种不同类型的cell在tableview上显示的时候,怎么在缓存池中找到

重用标识符!即需要重用的cell起名 identifier

2)cell重用的操作过程

  1、定义重用标识符

  2、在缓存池中寻找

  3、判断缓存池中是否有相应的cell 如果没有的话,就重新创建

  4、赋值新数据

  a \

NSString *identifier =@"cell";

  b\

UITableViewCell *cell =[tableview dequeueReusableCellWithIdentifier:identifier];

   c\

if(cell ==nil){

    cell =[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:identifier];

  d\

cell.textLabel.text =model.name;

}

 

五、模型的嵌套

1)在carmodel中导入 innermodel

if(self =[super init])

{

[self setValuesForKeyWithDictionary:dict];

 

ning 一直反应interface中没定义InnerCarinitWithDictionary方法 导入innercarmodel

        // InnerCarModel *innerModel =[[InnerCarModel alloc] InnerCarinitWithDictionary写法是错误的导致,不需要alloc

NSMutableArray *muArray =[NSMutableArray array];

for(NSDictionary *dict in self.cars)

{

InnerModel *model =[InnerModel InnerinitWithDictionary];

[muArray addObject:model];

}

self.cars =muArray;

return self;

}

2)在tableview中显示

组数:self.dataArray.count

行数:CarModel *model =self.dataArray[section];

return model.cars.count;

内容:

CarModel *model =self.dataArray[indexPath.section];

InnerModel *innermodel =model.cars[indexPath.row];

 

六、cell的编辑,增删

技术分享

 

Objective-c——UI基础开发第六天(UITableView)

标签:

原文地址:http://www.cnblogs.com/CityPe/p/5344510.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!