iOS-个人整理17 - UITableView表视图

一、UITableView
UITableView,也就是表视图,可以算是app中最重要的视图了,随处可见,中间这一圈就是,有一种列表的形势,但应用比较丰富,可以加图片,每行的高度也可自定

UITableView继承于UIScrollView,备其的滚动属性
UITableView通过分区和行来划分,每个分区为section,每行为row,编号都从0开始,系统专门提供了一个类NSIndexPath来整合section和row

从最基本最必要的说起吧
表视图的初始化

//Grouped属性,在滚动时分区头部一起移动 UITableView *myTableView = [[UITableView alloc]initWithFrame:self.view.bounds style:UITableViewStyleGrouped]; //添加到父视图<pre name="code" class="objc"> [self.view addSubview: myTableView];

设置两个代理

myTableView.delegate = self;//负责外观 myTableView.dataSource = self;//负责数据

导入代理需要的两个协议

@interface RootViewController ()<UITableViewDelegate,UITableViewDataSource>

实现必须实现的两个协议方法:
第一个,返回表视图每个分区的行数

//返回每个分区下的单元格个数,必须实现-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{ return 10;}

第二个,单元格的内容填充,这里有两种方法,注册的方法和直接创建的方法
这里有一个单元格重用机制的概念,大概的意思就是,屏幕显示多少cell,系统就提供多少内存,滚动出屏幕的cell就让自己的cell,给新滚动到屏幕上的cell使用

//定制每个单元格,indexPath:当前定位的单元格位置,它有两个属性:indexPath.section,indexPath.row
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ 
//cell重用机制 
//定义重用标示符 
static NSString* cellId = @"CELL"; 
//每次需要使用单元格的是,先根据重用标识符从重用队列中获取单元格,如果队列中没有,再进行初始化新的单元格 
//每次都会先创建一屏幕的cell,当有cell出屏幕,就会根据重用标识符添加到对应的重用队列中,当屏幕外的cell要进入屏幕,先从队列中获取,如果没有,则初始化cell 
//当重用cell时,需要对上面的控件程序赋值 
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellId]; 
//如果从重用队列中未获取cell,也就是Cell为空 
    if (!cell) { cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:cellId]; 
//系统提供的控件要配合不同的样式来使用 
    cell.detailTextLabel.text = @"detail详细内容";
           } 
//选中效果 cell.selectionStyle = UITableViewCellSelectionStyleNone; 
//辅助视图的样式,右侧会有一个小图标 
cell.accessoryType = UITableViewCellAccessoryCheckmark; 
//设置左侧图片 
cell.imageView.image = [UIImage imageNamed:@"b33"]; cell.textLabel.text = @"文字内容显示";  
//为相应位置返回定制好的单元格 
return cell;
}

//注册单元格之后的写法,不用判断cell是否存在,不用初始化,直接使用//需要在viewdidLoad中写下面这行注册代码//注册单元格, //第一个参数为所使用的单元格类型 
//第二个参数为单元格的重用标示符 
[myTableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"CELL"];
//但是无法修改cell的样式,只能使用default样式 
//-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
//{
// UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"CELL" forIndexPath:indexPath];
// cell.detailTextLabel.text = @"asdas";
// cell.textLabel.text = @"1111";
// return cell;
//}

cell自带的imageVIew会随图片大小进行变化,下面的代码会修改图片的大小

CGSize size = CGSizeMake(30, 40); 
UIImage *image = [UIImage imageNamed:@"mv_book_icon"]; 
//调整image的大小 UIGraphicsBeginImageContextWithOptions(size, NO,0.0); 
CGRect imageRect=CGRectMake(0.0, 0.0, size.width, size.height); 
[image drawInRect:imageRect]; 
//设置图片  
cell.imageView.image=UIGraphicsGetImageFromCurrentImageContext(); 
UIGraphicsEndImageContext();

写了上面这些必须内容,就可以在界面上显示出表视图,能运行就不会有什么错误
大概是下面的样子,内容的图片和text可以自己改
因为模拟器的分辨率不够,cell之间的分割线可能看不清


表视图的问题很多的,还有很多属性还是先上代码,慢慢理解
下面的完整代码添加了一些新内容:

TableView显示相关的属性:

 //行高 
myTableView.rowHeight = 70; 
//分割线 
myTableView.separatorColor = [UIColor blueColor]; 
myTableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine; 
//置顶视图 
myTableView.tableHeaderView = [[UIView alloc]init]; 
//置底视图 
myTableView.tableFooterView = [[UIView alloc]init]; 
//section标题的颜色 
myTableView.sectionIndexColor = [UIColor redColor];

UITableViewCell的属性

 //选中效果 
cell.selectionStyle = UITableViewCellSelectionStyleBlue; 
//辅助视图的样式 
cell.accessoryType = UITableViewCellAccessoryCheckmark; 
//设置左侧图片 
cell.imageView.image = [UIImage imageNamed:@"ck.jpg"]; 
//标题视图 
cell.textLabel.text = [NSString stringWithFormat:@"第%ld个cell,%ld个section",indexPath.row,indexPath.section]; 
//副标题视图 
cell.detailTextLabel.text = @"副标题";

对row和section进行操作

//插入一行row
 [self.myViewTable insertRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationLeft];  
//删除一行row//    
[self.myViewTable deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationTop];  
//删除一行row//   
 [self.myViewTable deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationTop]; 
//插入和删除section    
NSIndexSet *section = [NSIndexSet indexSetWithIndex:1];    
[self.myViewTable insertSections:section withRowAnimation:UITableViewRowAnimationFade];    
[self.myViewTable deleteSections:section withRowAnimation:UITableViewRowAnimationTop];  
//滚动到最后一行   
 [self.myViewTable scrollToRowAtIndexPath:indexPath atScrollPosition:UITableViewScrollPositionBottom animated:YES];  
//滚动table到最底部 //当前内容已经超过一屏 
if (_myTableView.contentSize.height >= _myTableView.bounds.size.height)
 {    
[self.myTableView setContentOffset: CGPointMake(0, self.myTableView.contentSize.height -self.myTableView.bounds.size.height)animated:YES];    
} 

通过相关的代理方法来实现的:
设置指定位置cell的高度

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath

添加右侧边栏的索引条

-(NSArray<NSString *> *)sectionIndexTitlesForTableView:(UITableView *)tableView

设置页眉的高度

-(CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section

设置分区标题

-(NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section

添加点击cell的方法
点击cell会触发方法

-(void)tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath

这里有点重要东西,我们可以根据cell得到IndexPath,也可以根据IndexPath得到cell
同时也可以根据点击的cell得到cell的IndexPath,有时我们需要在点击cell的代理方法外得知这个点击的是哪个cell

  //根据IndexPath得到cell   
 CustomTableViewCell *cell = [_myTableView cellForRowAtIndexPath:indexPath];    
//根据cell得到IndexPath   
 NSIndexPath *indexPath2 = [_myTableView indexPathForCell:cell];        
//根据点击得到cell的IndexPath    
NSIndexPath *indexPath3 = [_myTableView indexPathForSelectedRow];

完整的代码以及效果

#import "RootViewController.h"@interface RootViewController ()<UITableViewDelegate,UITableViewDataSource>@property (nonatomic,assign)int index;
//标记创建单元格的个数
@end
@implementation RootViewController
- (void)viewDidLoad {
 [super viewDidLoad]; 
//初始化 
self.index = 0; 
self.navigationItem.title = @"表视图学习"; self.navigationController.navigationBar.barTintColor = [UIColor colorWithRed:200/255.0 green:233/255.0 blue:160/255.0 alpha:1]; 
//表视图的初始化 
//Grouped,分区头部一起移动 
UITableView *myTableView = [[UITableView alloc]initWithFrame:self.view.bounds style:UITableViewStyleGrouped]; 
[self.view addSubview: myTableView]; 
//tabView属性 //分割线 
myTableView.separatorColor = [UIColor colorWithRed:200/255.0 green:233/255.0 blue:160/255.0 alpha:1]; myTableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine; 
myTableView.rowHeight = 100; 
//置顶视图// myTableView.tableFooterView = (一个石头) 
//表视图所有的方法都需要代理方法 
//表视图的代理方法有两个 
//一个偏重于外观 
//一个偏重于数据 
myTableView.delegate = self; 
myTableView.dataSource = self; 
//注册单元格, 
//第一个参数为所使用的单元格类型
 //第二个参数为单元格的重用标示符
 [myTableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"CELL"]; }
#pragma mark -- 表视图的代理方法
//定制每个单元格,indexPath:当前定位的单元格位置,它有两个属性:indexPath.section,indexPath.row
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{ 
//cell重用机制 
//定义重用标示符 
static NSString* cellId = @"CELL"; 
//每次需要使用单元格的是,先根据重用标识符从重用队列中获取单元格,如果队列中没有,再进行初始化新的单元格 
//每次都会先创建一屏幕的cell,当有cell出屏幕,就会根据重用标识符添加到对应的重用队列中,当屏幕外的cell要进入屏幕,先从队列中获取,如果没有,则初始化cell 
//当重用cell时,需要对上面的控件程序赋值 
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellId]; 
//如果从重用队列中未获取cell,也就是Cell为空 
if (!cell) { cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:cellId]; 
//系统提供的控件要配合不同的样式来使用 
cell.detailTextLabel.text = [NSString stringWithFormat:@"创建的第%d个单元格",self.index++]; } 
//选中效果 
cell.selectionStyle = UITableViewCellSelectionStyleBlue; 
//辅助视图的样式 
cell.accessoryType = UITableViewCellAccessoryCheckmark; 
//设置左侧图片 
cell.imageView.image = [UIImage imageNamed:@"b33"]; cell.textLabel.text = [NSString stringWithFormat:@"第%ld个cell,%ld个section",indexPath.row,indexPath.section]; 
//为相应位置返回定制好的单元格 return cell;}
//注册单元格之后的写法,不用判断cell是否存在,不用初始化,直接使用
//但是无法修改cell的样式,只能使用default样式 //-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath//{// UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"CELL" forIndexPath:indexPath];// cell.detailTextLabel.text = @"asdas";//// cell.textLabel.text = @"1111";// return cell;// //}//设置对应位置的cell的高度-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{ //不同分区的宽度不同 //使得奇数cell的高度为50,偶数为100 if (indexPath.row%2 == 0 && indexPath.section %2 == 0) { return 100; } else{ return 50; }}//设置页眉的高度-(CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section{ return 22;}
//索引条
-(NSArray<NSString *> *)sectionIndexTitlesForTableView:(UITableView *)tableView{ return [NSArray arrayWithObjects:@"A",@"B",@"C", nil];}
//点击cell之后执行的代理方法
//delect
-(void)tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath{ NSLog(@"点击了%ld分区下的%ld行的cell",indexPath.section,indexPath.row);}
//添加分区标题
-(NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section{ return @"分区标题";}
//返回每个分区下的单元格个数,必须实现
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{ return 2;}
//返回分区的个数,可选实现,不实现则默认只有一个分区
-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{ return 10;}
@end

效果如下


内容有点多,下篇进行单元格的编辑和表视图控制器

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容