`

分段Table View的使用(Grouped样式表格)

    博客分类:
  • ios
 
阅读更多
简介:上篇做了Table View的一些介绍 ,还做了一个TableView 的Plain样式的例子,这篇我们学习Grouped样式表的例子,还有用到前面读取Plist的知识(见iOS学习之 plist文件的读写),把Plist文件中的数据读取出来,放到Table view里展示出来。这里把全国30多个省份的城市,都列出来了,plist文件里还有城市的行政区,不过这里只列出省份和城市就ok了。效果图如下:


[img]

[/img]



那么开始吧。

1、新建项目

新的一个名称为TableViewGrouped的Single View Application项目,打开项目的xib文件,拖拽TableView控件到xib文件中,摆正位置。


2、给新建的TableView找到他的归属

选中新添的TableView ,Connection Inspector,找到delegate和datasource,从它们右边的圆圈拉线到Files Owner图标上,参考上篇的第3步:

[img]

[/img]


3、设置Table View的属性为Grouped样式
[img]

[/img]



4、导入plist文件

从其他文件夹导入Provineces.plist文件,这个文件我会传到源代码里,大家都能方便使用了,包括全国30个省份和城市,还有城市的区也有。
[img]

[/img]

[img]

[/img]


5、添加.h .m的实现代码。

.h文件添加一个property
#import <UIKit/UIKit.h>

@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)numberOfSectionsInTableView:(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 dequeueReusableCellWithIdentifier: 
                             GroupedTableIdentifier]; 
    if (cell == nil) { 
        cell = [[UITableViewCell alloc] 
                initWithStyle:UITableViewCellStyleDefault 
                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; 
}




重点介绍下这个方法:
返回所有省份名称的数组 ,通过点击右边的省份名称能快速定位到这个省份的城市,也就是快速定位到这个section。
- (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
    //返回省份的数组
    NSMutableArray *array = [NSMutableArray arrayWithCapacity:35];
    for (NSDictionary *dict in provinces) {
        [array addObject:[dict objectForKey:@"p_Name"]];
    }
    return array;
}



OK,运行。效果如下:
[img]

[/img]



试试改成plain样式的分段TableView看看:
[img]

[/img]




  • 大小: 132.3 KB
  • 大小: 82.6 KB
  • 大小: 27.7 KB
  • 大小: 61.4 KB
  • 大小: 136.3 KB
  • 大小: 142.4 KB
  • 大小: 91.4 KB
分享到:
评论

相关推荐

    IOS应用源码Demo-设置不同风格的table view样式-毕设学习.zip

    Plain样式通常用于无分组的线性列表,而Grouped样式则会在单元格之间创建分隔线,形成分组效果。 3. **自定义样式**:除了系统提供的样式外,开发者还可以通过自定义UITableViewCell来实现各种独特的视觉效果。这...

    IOS应用源码——设置不同风格的table view样式.rar

    Plain样式呈现为单一连续的列表,而Grouped样式将内容分组到不同的区域,每组有自己的背景色。 1. **样式设置**: - 使用`UITableViewStyle`枚举来设置表格样式,例如`UITableViewStylePlain`或`...

    IOS应用源码——设置不同风格的table view样式.zip

    本资源“IOS应用源码——设置不同风格的table view样式.zip”提供了关于如何自定义和美化UITableView的源代码示例,帮助开发者学习如何创建具有不同风格的表格视图。 首先,`mhnibtableviewcell.png`可能是一个截图...

    grouped_table.json

    grouped_table.json

    js 实现根据数组分组动态生成table(合并相同项)

    可以使用`document.createElement`方法创建`&lt;table&gt;`、`&lt;thead&gt;`、`&lt;tbody&gt;`等元素,并通过`innerHTML`设置单元格内容。同时,我们需要处理合并相同项的问题,这可以通过计算`rowspan`属性来实现。以下是一个简单的...

    IOS应用源码之设置不同风格的table view样式 .rar

    Plain样式创建的是无分组的连续列表,而Grouped样式则将内容分组显示,每组有自己的背景色。 2. 自定义Cell: - UITableViewCell是默认的Cell类型,但我们可以创建自定义的UITableViewCell子类来添加额外的UI元素...

    matlab读取数据表格并统计

    首先,MATLAB提供了`readtable`函数用于读取各种格式的数据表格,如CSV、Excel文件等。例如,如果你的数据文件是CSV格式,可以使用以下命令读取: ```matlab data = readtable('123.csv'); ``` 这里的'123.csv'是你...

    iOS storyboard 绘制 tableview 的demo

    storyboard 绘制 tableview 的demo 对于熟悉iOS storyboard 开发 理解 UITableViewController有帮助。 xcode 4.3.2 上测试通过 网上看了这么多例子,自己整理的,不容易啊,分享了。

    从零开始学iOS7开发系列教程-事务管理软件开发实战-Chapter81

    在本例中,我们选择Grouped样式,以获得更美观的分组显示效果,适合用于输入界面。 3. ** storyboard设计**: - 使用Xcode的Interface Builder编辑storyboard文件,通过选择Table View对象并修改Attributes ...

    史上最全的ios开发源码

    苹果公司最早于2007年1月9日的Macworld大会上公布这个系统,最初是设计给iPhone使用的,后来陆续套用到iPod touch、iPad以及Apple TV等苹果产品上。iOS与苹果的Mac OS X操作系统一样,它也是以Darwin为基础的,因此...

    IOS应用源码Demo-一个Navigation + 分組tableView的DemoNavigation 2-毕设学习.zip

    在iOS应用开发中,导航控制器(Navigation Controller)和分组表格视图(Grouped Table View)是两个重要的组件,常用于构建用户界面。本示例源码“DemoNavigation 2”是一个结合了这两个元素的iOS应用,适用于毕业...

    IOS TableViewGrouped 例子

    本示例“IOS TableView Grouped”主要关注的是分组表格视图(UITableViewStyleGrouped),它以清晰的分组形式展示数据,使用户界面更加整洁、易于阅读。 分组表格视图的特点是将数据分成多个段落或组,每个组有自己...

    iOS-使用表格视图UITableView

    UITableView可以设置为分组样式(style: .grouped),并可以添加右侧索引来快速跳转到特定的分组。 总结来说,"iOS-使用表格视图UITableView"项目涵盖了iOS开发中的基础列表展示技术,通过学习和实践,开发者可以...

    ios 表格样式实现,类似课程表,时间安排表

    1. **设置UITableView样式**:默认情况下,UITableView有两种样式:Plain和Grouped。在这个案例中,我们可能需要使用Plain样式,因为它允许创建无分组的连续单元格,更接近课程表的布局。 2. **自定义...

    Laravel开发-laravel-grouped-widgets

    在Laravel框架中,"Laravel Grouped Widgets"通常指的是将相关的UI组件或者视图元素组织成一组,以便更好地管理并重用代码。这有助于提高代码的可读性,减少重复工作,并保持应用的整洁性。下面我们将深入探讨这个...

    grouped_categories:Blackchart的Highcharts分组类别插件

    像任何其他Highcharts模块(例如,导出)一样,在Highcharts脚本标记下添加指向grouped-categories.js [removed]标记。 对于NPM用户: var Highcharts = require('highcharts'), HighchartsGroupedCategories = ...

    ios-常用的taBleView样式.zip

    Plain样式呈现单列无分组的列表,而Grouped样式则将内容分组显示,每组有独立的背景色,更适合作为章节或类别划分的数据展示。 在通讯录应用中,我们经常会看到一个边栏索引,允许用户快速滚动到以特定字母开头的...

    grouped_data_by_newspaper.xlsx

    grouped_data_by_newspaper.xlsx

    用Python实现数据的透视表的方法

    传统的做法是通过Microsoft Excel这样的表格软件来实现,而在使用Python进行数据处理时,我们可以借助pandas包来完成相似的操作。 首先,需要明确的是,数据透视表(Pivot Table)是一种交互式的表,它能够将大量...

Global site tag (gtag.js) - Google Analytics