转自:http://blog.csdn.net/tangaowen/article/details/6438362
1. 首先,Controller需要实现两个 delegate ,分别是 UITableViewDelegate 和 UITableViewDataSource
2.然后 UITableView对象的 delegate要设置为 self。
3. 然后就可以实现这些delegate的一些方法拉。
(1)- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;
这个方法返回 tableview 有多少个section
- //返回有多少个Sections
- - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
- {
- return 1;
- }
(2)- (NSInteger)tableView:(UITableView *)table numberOfRowsInSection:(NSInteger)section;
这个方法返回 对应的section有多少个元素,也就是多少行。
- - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
- {
- return 10;
- }
(3)- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
这个方法返回指定的 row 的高度。
- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section;
这个方法返回指定的 section的header view 的高度。
- (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section;
这个方法返回指定的 section的footer view 的高度。
(4)- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;
返回指定的row 的cell。这个地方是比较关键的地方,一般在这个地方来定制各种个性化的 cell元素。这里只是使用最简单最基本
的cell 类型。其中有一个主标题 cell.textLabel 还有一个副标题cell.detailTextLabel, 还有一个 image在最前头 叫
cell.imageView. 还可以设置右边的图标,通过cell.accessoryType 可以设置是饱满的向右的蓝色箭头,还是单薄的向右箭头,
还是勾勾标记。
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- static NSString * showUserInfoCellIdentifier = @"ShowUserInfoCell";
- UITableViewCell * cell = [tableView_ dequeueReusableCellWithIdentifier:showUserInfoCellIdentifier];
- if (cell == nil)
- {
- // Create a cell to display an ingredient.
- cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle
- reuseIdentifier:showUserInfoCellIdentifier]
- autorelease];
- }
- // Configure the cell.
- cell.textLabel.text=@"签名";
- cell.detailTextLabel.text = [NSString stringWithCString:userInfo.user_signature.c_str() encoding:NSUTF8StringEncoding];
- }
(5)- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section
返回指定的 section 的header的高度
- - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section
- {
- if (section ==0)
- return 80.0f;
- else
- return 30.0f;
- }
(6)- (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
返回指定的section 的 header 的 title,如果这个section header 有返回view,那么title就不起作用了。
- - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section
- {
- if (tableView == tableView_)
- {
- if (section == 0)
- {
- return @"title 1";
- }
- else if (section == 1)
- {
- return @"title 2";
- }
- else
- {
- return nil;
- }
- }
- else
- {
- return nil;
- }
- }
(7) - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section
返回指定的 section header 的view,如果没有,这个函数可以不返回view
- - (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section
- {
- if (section == 0)
- {
- UIView* header = [[[NSBundle mainBundle] loadNibNamed: @"SettingHeaderView"
- owner: self
- options: nil] lastObject];
- else
- {
- return nil;
- }
- }
(8) - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
当用户选中某个行的cell的时候,回调用这个。但是首先,必须设置tableview的一个属性为可以select 才行。
- TableView.allowsSelection=YES;
- cell.selectionStyle=UITableViewCellSelectionStyleBlue;
如果不希望响应select,那么就可以用下面的代码设置属性:
- TableView.allowsSelection=NO;
下面是响应select 点击函数,根据哪个section,哪个row 自己做出响应就好啦。
- - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
- {
- if (indexPath.section == 1)
- {
- return;
- }
- else if(indexPath.section==0)
- {
- switch (indexPath.row)
- {
- //聊天
- case 0:
- {
- [self onTalkToFriendBtn];
- }
- break;
- default:
- break;
- }
- }
- else
- {
- return ;
- }
- }
如何让cell 能够响应 select,但是选中后的颜色又不发生改变呢,那么就设置
cell.selectionStyle = UITableViewCellSelectionStyleNone;
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- //cell被选中后的颜色不变
- cell.selectionStyle = UITableViewCellSelectionStyleNone;
- }
(9)如何设置tableview 每行之间的 分割线
- self.tableView.separatorStyle=UITableViewCellSeparatorStyleSingleLine;
如果不需要分割线,那么就设置属性为 UITableViewCellSeparatorStyleNone 即可。
(10)如何设置 tableview cell的背景颜色
- - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- //设置背景颜色
- cell.contentView.backgroundColor=[UIColor colorWithRed:0.957 green:0.957 blue:0.957 alpha:1];
- }
(11) - (void)tableView:(UITableView *)tableView accessoryButtonTappedForRowWithIndexPath:(NSIndexPath *)indexPath
这个函数响应,用户点击cell 右边的 箭头(如果有的话)
(12)如何设置tableview 可以被编辑
首先要进入编辑模式:
- [TableView setEditing:YES animated:YES];
如果要退出编辑模式,肯定就是设置为NO
- (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
返回当前cell 要执行的是哪种编辑,下面的代码是 返回 删除 模式
- - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
- {
- return UITableViewCellEditingStyleDelete;
- }
-(void) tableView:(UITableView *)aTableView
commitEditingStyle:(UITableViewCellEditingStyle) editingStyle
forRowAtIndexPath:(NSIndexPath *)indexPath
通知告诉用户编辑了 哪个cell,对应上面的代码,我们在这个函数里面执行删除cell的操作。
- -(void) tableView:(UITableView *)aTableView
- commitEditingStyle:(UITableViewCellEditingStyle) editingStyle
- forRowAtIndexPath:(NSIndexPath *)indexPath
- {
- [chatArray removeObjectAtIndex:indexPath.row];
- [chatTableView reloadData];
- }
(13)如何获得 某一行的CELL对象
- (UITableViewCell *)cellForRowAtIndexPath:(NSIndexPath *)indexPath;
相关推荐
一、UITableView基本结构 UITableView主要由两部分构成:UITableView对象和UITableViewCell对象。UITableView是容器,负责显示和管理所有的单元格(cells),而UITableViewCell则是列表中的每一行。 二、创建...
在这个"iOS UI基础 UITableView 团购代码"示例中,我们将探讨如何使用XIB(Interface Builder中的用户界面文件)自定义UITableViewCell来构建一个团购应用的界面布局。 首先,让我们理解一下XIB文件的作用。XIB...
以上就是关于iOS中UITableView使用的一些常见问题和解决办法,包括设置headerView、去除分割线、自动计算高度、禁用默认分割线、自定义section和row、处理点击阴影以及iPad的缩进问题。理解并熟练运用这些技巧,可以...
总结,UITableView是iOS应用中不可或缺的组件,它提供了展示大量数据的高效方式。通过理解并熟练掌握UITableView的数据源、委托、单元格自定义以及性能优化,开发者能够构建出功能丰富的交互式列表界面。在实际项目...
为了有效地使用`UITableView`,开发者需要理解其数据源的原理,并能够正确地实现`UITableViewDataSource`协议中的方法。此外,还需要掌握如何根据不同的需求选择合适的样式,以及如何通过代码或Storyboard来配置这些...
- SQLite:基本SQL操作,结合FMDB库在iOS中的使用。 - UserDefaults:简单数据的存储和读取。 7. **Apple框架和API**: - Core Location:获取和处理用户位置信息。 - Core Data:用于应用程序的数据模型层。 ...
### IOS面试题2018总结188题知识点概览 #### 1. Swift与Objective-C的区别 - **语法差异**:Swift 是一种更现代的语言,拥有许多新特性,如类型推断、模式匹配等。 - **内存管理**:Swift 使用自动引用计数 (ARC) ...
本代码示例主要探讨了 `UITableView` 的基本使用方法,以及如何与 `UINavigationController` 配合实现导航功能,特别是逆向传值。 首先,我们来详细了解一下 `UITableView`。`UITableView` 是 iOS 中的一种视图控件...
在iOS开发中,UITableView是用于显示列表数据的重要控件,而下拉刷新功能则成为现代应用的标准特性之一,它允许用户在顶部拉动表格时获取最新的数据。`UITableView`的下拉刷新功能通常通过第三方库来实现,其中`...
### iOS的基本的设计模式 #### 一、Model-View-Controller (MVC) **Model-View-Controller**(简称MVC)是一种广泛应用于软件工程中的设计模式,在iOS开发中更是被视为核心设计模式之一。该模式的核心理念是将应用...
Objective-C是Swift之前的iOS开发语言,虽然现在使用较少,但理解其基本语法和与Cocoa Touch框架的交互对于阅读旧代码或了解历史实现仍然是必要的。 Cocoa Touch是iOS应用开发的主要框架,包含UIKit、Foundation等...
在iOS开发中,`UIScrollView`和`UITableView`是两种非常重要的视图组件,它们用于展示大量数据并允许用户滚动查看。这两个组件的布局设计对于用户体验至关重要。本篇文章将深入探讨`UIScrollView`和`UITableView`...
总结,UITableView的修改涉及数据源的更新、代理方法的实现以及各种编辑操作的处理。熟练掌握这些知识点,可以构建出功能丰富的表格视图,为用户提供直观且高效的交互体验。通过实际项目中的不断实践和调试,你将...
本文详细介绍了 UITableView 的基本使用方法,并提供了完整的示例代码。通过这些内容,开发者可以更好地理解和使用 UITableView,构建出更丰富的列表界面。希望本文能帮助开发者解决 UITableView 使用过程中的常见...
本篇文章将深入探讨代理模式的基本概念、工作原理及其在iOS中的实际应用。 **代理模式的定义与分类** 代理模式是一种结构型设计模式,它为一个对象提供一个替身或者代表,以便控制对原对象的访问。代理对象在客户端...
1. UITableView的基本使用,包括数据源和代理方法。 2. 自定义UITableViewCell以满足特定的UI需求。 3. 处理用户交互,实现展开和收缩列表的逻辑。 4. 利用动画效果增强用户体验。 5. 可能会涉及到Core Data或其它...
总结来说,这个实例展示了如何在iOS应用中集成基本的表格功能、搜索功能以及刷新加载机制。通过理解这些代码,开发者可以构建出更复杂的用户界面,提供更丰富的交互体验。同时,了解如何利用代理和协议来协调不同...
总结,使用Masonry处理UITableViewCell的自动行高计算,需要注意布局约束的完整性、正确使用UITableView的自动行高特性,以及适时触发布局更新。通过理解这些核心概念和解决常见问题,可以创建出响应式且高效的列表...
总结起来,UITableView的使用涵盖了数据管理、用户交互、界面定制等多个方面。理解并熟练掌握这些知识点,对于iOS开发者来说至关重要,能帮助你构建出高效且易用的数据展示界面。在实际项目中,你可能还会遇到更多...