那么开始吧。
1、新建项目
新的一个名称为TableViewGrouped的Single View Application项目,打开项目的xib文件,拖拽TableView控件到xib文件中,摆正位置。
2、给新建的TableView找到他的归属
选中新添的TableView ,Connection Inspector,找到delegate和datasource,从它们右边的圆圈拉线到Files Owner图标上,参考上篇的第3步:
3、设置Table View的属性为Grouped样式
4、导入plist文件
从其他文件夹导入Provineces.plist文件,这个文件我会传到源代码里,大家都能方便使用了,包括全国30个省份和城市,还有城市的区也有。
5、添加.h .m的实现代码。
.h文件添加一个property
- #import
-
- @interface
ViewController : UIViewController - @property
(strong, nonatomic) NSArray *provinces; - @end
第一步从Plist读取出数据,第二步给Table添加数据。
在viewDidLoad读取Plist,plist是个array类型的,所以使用Array读取。
.m文件的实现。
- @implementation
ViewController - @synthesize
provinces; -
- -
(void)viewDidLoad - {
-
[super viewDidLoad]; -
// Do any additional setup after loading the view, typically from a nib. -
NSBundle *bundle = [NSBundle mainBundle]; -
NSString *plistPath = [bundle pathForResource:@"Provineces" ofType:@"plist"]; -
NSMutableArray *array=[[NSMutableArray alloc] initWithContentsOfFile:plistPath]; -
self.provinces = array; -
- }
实现TableView表格部分,下面这些方法看方法名就能大概明白意思。
-
这个方法用来告诉表格有几个分组
- -
(NSInteger)numberOfSectionsInTableV iew:(UITableView *)tableView { -
return [provinces count]; - }
- 这个方法告诉表格第section个分段有多少行
- -
(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section { -
NSArray *cities = [[provinces objectAtIndex:section]objectForKey:@"Citys"]; -
return [cities count]; - }
-
这个方法用来告诉某个分组的某一行是什么数据,返回一个UITableViewCell
- -
(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { -
NSUInteger section = [indexPath section]; -
NSUInteger row = [indexPath row]; -
-
-
NSArray *cities = [[provinces objectAtIndex:section]objectForKey:@"Citys"] ; -
-
-
static NSString *GroupedTableIdentifier = @"cell"; -
UITableViewCell *cell = [tableView dequeueReusableCellWithI dentifier: -
GroupedTableIdentifier]; -
if (cell == nil) { -
cell = [[UITableViewCell alloc] -
initWithStyle:UITableViewCellStyleDefa ult -
reuseIdentifier:GroupedTableIdentifier]; -
} -
-
//给Label附上城市名称 key 为:C_Name -
cell.textLabel.text = [[cities objectAtIndex:row] objectForKey:@"C_Name"]; -
return cell; - }
- 这个方法用来告诉表格第section分组的名称
- -
(NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section { -
NSString *provincName = [[provinces objectAtIndex:section] objectForKey:@"p_Name"]; -
return provincName; - }
- 重点介绍下这个方法:
- -
(NSArray *)sectionIndexTitlesForTab leView:(UITableView *)tableView { -
//返回省份的数组 -
NSMutableArray *array = [NSMutableArray arrayWithCapacity:35]; -
for (NSDictionary *dict in provinces) { -
[array addObject:[dict objectForKey:@"p_Name"]]; -
} -
return array; - }
OK,运行。效果如下:
试试改成plain样式的分段TableView看看:
以上例子的全部