(小白文章)
1.UITableView的结构
_listArray = [[UIFont familyNames] retain];//获取所有字体名称
_tableView = [[UITableView alloc] initWithFrame:view.bounds style:UITableViewStylePlain];
//设置数据源
_tableView.dataSource =self;
//设置代理
_tableView.delegate =self;
// 设置表视图cell的高度,统一的高度
_tableView.rowHeight = 70;// 默认44px
//设置表视图的背景
UIImageView*backgroundView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"IMG_0410"]];
_tableView.backgroundView = backgroundView;
[backgroundView release];
//设置表视图的颜色
_tableView.backgroundColor = [UIColor yellowColor];
// 设置表视图的分割线的颜色
_tableView.separatorColor = [UIColor purpleColor];
// 设置表视图的分割线的风格
_tableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine;
//设置表视图的头部视图(headView添加子视图)
UIView*headerView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 80)];
headerView.backgroundColor = [UIColor redColor];
//添加子视图
UILabel*headText = [[UILabel alloc] initWithFrame:CGRectMake(60, 0, 200, 80)];
headText.text =@"天晴朗,天晴朗天晴朗天晴朗!";
headText.numberOfLines = 0;
[headerView addSubview:headText];
[headText release];
_tableView.tableHeaderView = headerView;//设置头部
[headerView release];
//设置表视图的尾部视图(footerView添加子视图)
UIView*footerView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 80)];
footerView.backgroundColor = [UIColor yellowColor];
_tableView.tableFooterView = footerView;//设置尾部
[footerView release];
//整体刷新UITableView
- (void)reloadData;
//指定一个cell,返回一个NSIndexPath,如果cell没有,返回nil
- (NSIndexPath*)indexPathForCell:(UITableViewCell*)cell;
//指定一个范围,返回一组NSIndexPath,如果rect无效,返回nil
- (NSArray*)indexPathsForRowsInRect:(CGRect)rect;
//指定一个NSIndexPath,返回一个cell
- (UITableViewCell*)cellForRowAtIndexPath:(NSIndexPath*)indexPath;
//返回所有显示的cell
- (NSArray*)visibleCells;
//返回所有显示的cell的NSIndexPath
- (NSArray*)indexPathsForVisibleRows;
UITableView数据源方法
//UITableView有多少个组
- (NSInteger)numberOfSectionsInTableView:(UITableView*)tableView{
return1;//默认为1
}
//UITableView每组有多少条数据
- (NSInteger)tableView:(UITableView*)tableView numberOfRowsInSection:(NSInteger)section;
{
return[_listArray count];
}
//创建一个cell
- (UITableViewCell*)tableView:(UITableView*)tableView cellForRowAtIndexPath:(NSIndexPath*)indexPath
{
staticNSString*cellIdentifier =@"cell";
UITableViewCell*cell = [tableView dequeueReusableCellWithIdentifier:cellIdentifier];
if(cell == nil) {
cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellIdentifier] autorelease];
//cell的四种样式
//UITableViewCellStyleDefault,只显示图片和标题
//UITableViewCellStyleValue1,显示图片,标题和子标题(子标题在右边)
//UITableViewCellStyleValue2,标题和子标题
//UITableViewCellStyleSubtitle显示图片,标题和子标题(子标题在下边)
}
// 指向其中一行
// cell.textLabel.text = [self.listArray objectAtIndex:indexPath.row];//设置cell的标题
cell.textLabel.textColor = [UIColor redColor];//设置标题字体颜色
cell.textLabel.font = [UIFont fontWithName:fontName size:18];//设置标题字体大小
cell.imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@""]];//设置cell的图片
cell.detailTextLabel =@"detailTextLabel"// 设置cell的子标题
returncell;
}
//设置组头部的文字
- (NSString*)tableView:(UITableView*)tableView titleForHeaderInSection:(NSInteger)section;
//设置组尾部的文字
- (NSString*)tableView:(UITableView*)tableView titleForFooterInSection:(NSInteger)section;
//指定cell是否可编辑
- (BOOL)tableView:(UITableView*)tableView canEditRowAtIndexPath:(NSIndexPath*)indexPath;
//指定cell是否可移动
- (BOOL)tableView:(UITableView*)tableView canMoveRowAtIndexPath:(NSIndexPath*)indexPath;
//提交编辑操作,重写此方法,自动实现cell左滑动删除功能
- (void)tableView:(UITableView*)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath*)indexPath;
//移动cell
- (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath;
//右边索引显示的内容
- (NSArray*)sectionIndexTitlesForTableView:(UITableView*)tableView
{
return_keyArray;
}
//点击右边索引跳转到哪个index位置
- (NSInteger)tableView:(UITableView*)tableView sectionForSectionIndexTitle:(NSString*)title atIndex:(NSInteger)index
{
returnindex;
}
UITableView常用的代理方法
//cell的行高
- (CGFloat)tableView:(UITableView*)tableView heightForRowAtIndexPath:(NSIndexPath*)indexPath;
//组头部的高度
- (CGFloat)tableView:(UITableView*)tableView heightForHeaderInSection:(NSInteger)section;
//组尾部的高度
- (CGFloat)tableView:(UITableView*)tableView heightForFooterInSection:(NSInteger)section;
//自定义组头部视图,此方法和数据源中设置头部标题的方法只能实现一个
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section; // custom view for header. will be adjusted to default or specified header height
//自定义组尾部视图,此方法和数据源中设置尾部标题的方法只能实现一个
- (UIView*)tableView:(UITableView*)tableView viewForFooterInSection:(NSInteger)section;
//点击cell时调用
- (void)tableView:(UITableView*)tableView didSelectRowAtIndexPath:(NSIndexPath*)indexPath;
//取消点击cell时调用
- (void)tableView:(UITableView*)tableView didDeselectRowAtIndexPath:(NSIndexPath*)indexPath NS_AVAILABLE_IOS(3_0);
UITableViewCell的一些辅助功能
//cell的选中样式
cell.selectionStyle = UITableViewCellSelectionStyleBlue;
如果想选中后取消,在didSelectRowAtIndexPath方法中调用
[tableViewdeselectRowAtIndexPath:indexPathanimated:YES];或
[self performSelector:@selector(deselectRowAtIndexPath:animated:) withObject:indexPath afterDelay:.5];
如果想在cell的右边出现选中状态或箭头可以设置下面的属性
cell.accessoryType = UITableViewCellAccessoryCheckmark;
cell根据文字的多少自适应高度
- (CGFloat)tableView:(UITableView*)tableView heightForRowAtIndexPath:(NSIndexPath*)indexPath
{
// wrong UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
NSString*text = [_listArray objectAtIndex:indexPath.row];
//320为文字显示的宽度,高度1000是随便写的,会自动根据文字的大小和宽度计算出高度
CGSize size = [text sizeWithFont:[UIFont systemFontOfSize:14] constrainedToSize:CGSizeMake(320, 1000)];
// +20是为了让每个cell之间有些间隔
returnsize.height+20;
}
UItableView设置偏移量
[myTableView setContentOffset:CGPointMake(0, 100) animated:YES];
刷新某行cell的方法
NSIndexPath*indexPath_1=[NSIndexPath indexPathForRow:1 inSection:0];
NSArray*indexArray=[NSArray arrayWithObject:indexPath_1];
[myTableView reloadRowsAtIndexPaths:indexArray withRowAnimation:UITableViewRowAnimationAutomatic];
改变分组列表之间的间距
方法一
改变每一组之间的间距
self.tableView.sectionHeaderHeight = 5;
self.tableView.sectionFooterHeight = 0;
方法二
- (CGFloat)tableView:(UITableView*)tableView heightForHeaderInSection:(NSInteger)section
{
return5;
}
- (CGFloat)tableView:(UITableView*)tableView heightForFooterInSection:(NSInteger)section
{
return5;
}
- (UIView*)tableView:(UITableView*)tableView viewForHeaderInSection:(NSInteger)section
{
UIView*view = [[UIView alloc] initWithFrame:CGRectZero];
returnview;
}
- (UIView*)tableView:(UITableView*)tableView viewForFooterInSection:(NSInteger)section
{
UIView*view = [[UIView alloc] initWithFrame:CGRectZero];
returnview;
}
iOS7上tableView的分割线左边间距为0
if([_tableView respondsToSelector:@selector(setSeparatorInset:)]) {
[_tableView setSeparatorInset:UIEdgeInsetsZero];
}
设置tableview的cell颜色
//方法一:
cell.contentView.backgroundColor = [UIColor redColor];
//方法二:
UITableViewCell*cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
UIView* bgview = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 1, 1)];
bgview.opaque =YES;
bgview.backgroundColor = [UIColor orangeColor];
[cell setBackgroundView:bgview];
//方法三:
- (void)tableView:(UITableView*)tableView willDisplayCell:(UITableViewCell*)cell forRowAtIndexPath:(NSIndexPath*)indexPath
{
cell.backgroundColor = [UIColor redColor];
}
调整cell之间的距离
#pragma mark重写setFrame方法,自己调整cell的frame
- (void)setFrame:(CGRect)frame
{
// tableView边框的宽度#define kTableBorderWidth 5
// 更改x、宽度
frame.origin.x = kTableBorderWidth;
frame.size.width -=kTableBorderWidth* 2;
//更改顶部间距、每个cell之间的间距
frame.origin.y += kTableTopBorderWidth;
frame.size.height -= kTableViewCellMargin;
[super setFrame:frame];
}
cell选中和不选中显示不同背景
cell.selectedBackgroundView= [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item_selected.jpg"]];
cell.backgroundView= [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"choose_item.jpg"]];