UITableView整理

1.UITableView有两种样式:字体

[objc] view plaincopy在CODE上查看代码片派生到个人代码片动画

  1. [[UITableView alloc] initWithFrame:view.bounds style:UITableViewStylePlain];  atom

  2. [[UITableView alloc] initWithFrame:view.bounds style:UITableViewStyleGrouped];  spa


2.UITableView的结构:
.net

UITableView由头部,尾部,和中间一连串的单元格组成,UITableView的头部由tableHeaderView属性设置,尾部由tableFooterView属性设置,中间的代理

行高可经过rowHeight属性设置code

[objc] view plaincopy在CODE上查看代码片派生到个人代码片orm

  1. _listArray = [[UIFont familyNames] retain];//获取全部字体名称  blog

  2.   

  3. _tableView = [[UITableView alloc] initWithFrame:view.bounds style:UITableViewStylePlain];  索引

  4. // 设置数据源  

  5. _tableView.dataSource = self;  

  6. // 设置代理  

  7. _tableView.delegate = self;  

  8. // 设置表视图cell的高度,统一的高度  

  9. _tableView.rowHeight = 70;    // 默认44px  

  10. // 设置表视图的背景  

  11. UIImageView *backgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"IMG_0410"]];  

  12. _tableView.backgroundView = backgroundView;  

  13. [backgroundView release];  

  14. // 设置表视图的颜色  

  15.   _tableView.backgroundColor = [UIColor yellowColor];  

  16. // 设置表视图的分割线的颜色  

  17.   _tableView.separatorColor = [UIColor purpleColor];  

  18. // 设置表视图的分割线的风格  

  19. _tableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine;  

  20. // 设置表视图的头部视图(headView 添加子视图)  

  21. UIView *headerView = [[UIView alloc] initWithFrame:CGRectMake(0032080)];  

  22. headerView.backgroundColor = [UIColor redColor];  

  23. // 添加子视图  

  24. UILabel *headText = [[UILabel alloc] initWithFrame:CGRectMake(60020080)];  

  25. headText.text = @"天晴朗,天晴朗天晴朗天晴朗!";  

  26. headText.numberOfLines = 0;  

  27. [headerView addSubview:headText];  

  28. [headText release];  

  29. _tableView.tableHeaderView = headerView; //设置头部  

  30. [headerView release];  

  31. // 设置表视图的尾部视图(footerView 添加子视图)      

  32. UIView *footerView = [[UIView alloc] initWithFrame:CGRectMake(0032080)];  

  33. footerView.backgroundColor = [UIColor yellowColor];  

  34. _tableView.tableFooterView = footerView;  //设置尾部  

  35. [footerView release];  


UITableView的一些经常使用属性

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //设置UITableView分割线风格  

  2. @property(nonatomic) UITableViewCellSeparatorStyle separatorStyle;   

  3. //设置UITableView分割线颜色,默认为标准灰色  

  4. @property(nonatomic,retain) UIColor               *separatorColor;    

  5. //设置UITableView的头部  

  6. @property(nonatomic,retainUIView *tableHeaderView;   

  7. //设置UITableView的尾部  

  8. @property(nonatomic,retainUIView *tableFooterView;   

  9. //设置UITableView的Cell的高度  

  10. @property (nonatomic)          CGFloat                     rowHeight;  

  11. //设置UITableView种section的头部的高度  

  12. @property (nonatomic)          CGFloat                     sectionHeaderHeight;  

  13. //设置UITableView种section的尾部的高度  

  14. @property (nonatomic)          CGFloat                     sectionFooterHeight;  

  15. //设置UITableView的背景  

  16. @property(nonatomicreadwriteretainUIView *backgroundView NS_AVAILABLE_IOS(3_2);  

  17. //设置UITableView是否可编辑,默认为no,不可编辑  

  18. @property(nonatomic,getter=isEditing) BOOL editing;   

  19. - (void)setEditing:(BOOL)editing animated:(BOOL)animated;//方法带有动画效果  

  20. //当UITableView不在编辑时,cell是否能够选中,默认为yes  

  21. @property(nonatomicBOOL allowsSelection NS_AVAILABLE_IOS(3_0);    

  22. //当UITableView在编辑时,cell是否能够选中,默认为no  

  23. @property(nonatomicBOOL allowsSelectionDuringEditing;      

  24. //当UITableView不在编辑时,cell是否能够选中多个,默认为no                                  

  25. @property(nonatomicBOOL allowsMultipleSelection NS_AVAILABLE_IOS(5_0);    

  26. //当UITableView在编辑时,cell是否能够选中多个,默认为no  

  27. @property(nonatomicBOOL allowsMultipleSelectionDuringEditing NS_AVAILABLE_IOS(5_0);   

UITableView的一些经常使用方法:

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //总体刷新UITableView  

  2. - (void)reloadData;   

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //指定一个cell,返回一个NSIndexPath,若是cell没有,返回nil  

  2. - (NSIndexPath *)indexPathForCell:(UITableViewCell *)cell;   

  3. //指定一个范围,返回一组NSIndexPath,若是rect无效,返回nil  

  4. - (NSArray *)indexPathsForRowsInRect:(CGRect)rect;   

  5. //指定一个NSIndexPath,返回一个cell  

  6. - (UITableViewCell *)cellForRowAtIndexPath:(NSIndexPath *)indexPath;   

  7. //返回全部显示的cell  

  8. - (NSArray *)visibleCells;  

  9. //返回全部显示的cell的NSIndexPath  

  10. - (NSArray *)indexPathsForVisibleRows;  


UITableView的一些编辑方法:

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //插入一个cell到指定的indexPaths位置,指定一个动画效果  

  2. - (void)insertRowsAtIndexPaths:(NSArray *)indexPaths withRowAnimation:(UITableViewRowAnimation)animation;  

  3. //删除indexPaths位置的cell,指定一个动画效果  

  4. - (void)deleteRowsAtIndexPaths:(NSArray *)indexPaths withRowAnimation:(UITableViewRowAnimation)animation;  

  5. //刷新indexPaths位置的cell,指定一个动画效果(tableView的局部刷新,通常用于cell的位置不改变,又不想刷新整个tableView时)  

  6. - (void)reloadRowsAtIndexPaths:(NSArray *)indexPaths withRowAnimation:(UITableViewRowAnimation)animation NS_AVAILABLE_IOS(3_0);  

  7. //移动indexPaths位置的cell,指定一个动画效果  

  8. - (void)moveRowAtIndexPath:(NSIndexPath *)indexPath toIndexPath:(NSIndexPath *)newIndexPath NS_AVAILABLE_IOS(5_0);  

UITableView数据源方法

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //UITableView有多少个组  

  2. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{  

  3.     return 1;//默认为1  

  4. }  

  5. //UITableView每组有多少条数据  

  6. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section;  

  7. {  

  8.     return [_listArray count];  

  9. }   

  10.   

  11. //建立一个cell  

  12. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath  

  13. {  

  14.     static NSString *cellIdentifier = @"cell";  

  15.     UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];  

  16.     if (cell == nil) {  

  17.         cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellIdentifier] autorelease];  

  18.     //cell的四种样式  

  19.     //UITableViewCellStyleDefault,       只显示图片和标题  

  20.        //UITableViewCellStyleValue1,        显示图片,标题和子标题(子标题在右边)  

  21.        //UITableViewCellStyleValue2,        标题和子标题  

  22.        //UITableViewCellStyleSubtitle       显示图片,标题和子标题(子标题在下边)  

  23.   

  24.     }  

  25.     // 指向其中一行  

  26. //    cell.textLabel.text = [self.listArray objectAtIndex:indexPath.row];//设置cell的标题  

  27.     cell.textLabel.textColor = [UIColor redColor];//设置标题字体颜色  

  28.     cell.textLabel.font = [UIFont fontWithName:fontName size:18];//设置标题字体大小  

  29.     cell.imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@""]];//设置cell的图片  

  30.     cell.detailTextLabel = @"detailTextLabel"// 设置cell的子标题  

  31.     return cell;  

  32.       

  33. }   

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //设置组头部的文字  

  2. - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section;   

  3. //设置组尾部的文字  

  4. - (NSString *)tableView:(UITableView *)tableView titleForFooterInSection:(NSInteger)section;  

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //指定cell是否可编辑  

  2. - (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath;  

  3. //指定cell是否可移动  

  4. - (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath;  

  5. //提交编辑操做,重写此方法,自动实现cell左滑动删除功能  

  6. - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath;  

  7. // 移动cell  

  8. - (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath;  

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //右边索引显示的内容  

  2. - (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView  

  3. {  

  4.     return _keyArray;  

  5. }   

  6. // 点击右边索引跳转到哪一个index位置  

  7. - (NSInteger)tableView:(UITableView *)tableView sectionForSectionIndexTitle:(NSString *)title atIndex:(NSInteger)index  

  8. {  

  9.     return index;  

  10. }   

UITalbeView经常使用的代理方法

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. //cell的行高  

  2. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;  

  3. //组头部的高度  

  4. - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section;  

  5. //组尾部的高度  

  6. - (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section;  

  7. //自定义组头部视图,此方法和数据源中设置头部标题的方法只能实现一个  

  8. - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section;   // custom view for header. will be adjusted to default or specified header height  

  9. //自定义组尾部视图,此方法和数据源中设置尾部标题的方法只能实现一个  

  10. - (UIView *)tableView:(UITableView *)tableView viewForFooterInSection:(NSInteger)section;    

  11. //点击cell时调用  

  12. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;  

  13. //取消点击cell时调用  

  14. - (void)tableView:(UITableView *)tableView didDeselectRowAtIndexPath:(NSIndexPath *)indexPath NS_AVAILABLE_IOS(3_0);  


UITableViewCell的一些辅助功能

//sell的选中样式

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. cell.selectionStyle = UITableViewCellSelectionStyleBlue;  

若是想选中后取消,在didSelectRowAtIndexPath方法中调用

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. [tableView deselectRowAtIndexPath:indexPath animated:YES];或  

  2. [self performSelector:@selector(deselectRowAtIndexPath:animated:) withObject:indexPath afterDelay:.5];  

若是想在cell的右边出现选中状态或箭头能够设置下面的属性

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1. cell.accessoryType = UITableViewCellAccessoryCheckmark;  

cell根据文字的多少自适应高度

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

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

  2. {  

  3.     // wrong  UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];  

  4.     NSString *text = [_listArray objectAtIndex:indexPath.row];  

  5.     //320为文字显示的宽度,高度1000是随便写的,会自动根据文字的大小和宽度计算出高度  

  6.     CGSize size = [text sizeWithFont:[UIFont systemFontOfSize:14] constrainedToSize:CGSizeMake(3201000)];  

  7.     // +20是为了让每一个cell之间有些间隔  

  8.     return size.height+20;  

  9. }  

[objc] view plaincopy在CODE上查看代码片派生到个人代码片

  1.     //这样写在IOS7.0之后 TableViewCell的分割线就不会往右挫15个像素点了  

  2.    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:SimpleTableIdentifier];  

  3. [tableViewsetSeparatorInset:UIEdgeInsetsMake(0,0,0,0)]; 

相关文章
相关标签/搜索