文档章节

iOS学习之分段Table View的使用(Grouped样式表格)

 谢锡鹏
发布于 2014/04/12 23:22
字数 817
阅读 5387
收藏 3
点赞 0
评论 0

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




那么开始吧。

1、新建项目

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


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

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


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




4、导入plist文件

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

 

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

.h文件添加一个property

[cpp] view plaincopy

  1. #import <UIKit/UIKit.h>  

  2.   

  3. @interface ViewController : UIViewController  

  4. @property (strong, nonatomic) NSArray *provinces;  

  5. @end  



第一步从Plist读取出数据,第二步给Table添加数据。

在viewDidLoad读取Plist,plist是个array类型的,所以使用Array读取。

.m文件的实现。

[cpp] view plaincopy

  1. @implementation ViewController  

  2. @synthesize provinces;  

  3.   

  4. - (void)viewDidLoad  

  5. {  

  6.     [super viewDidLoad];  

  7.     // Do any additional setup after loading the view, typically from a nib.  

  8.     NSBundle *bundle = [NSBundle mainBundle];  

  9.     NSString *plistPath = [bundle pathForResource:@"Provineces" ofType:@"plist"];  

  10.     NSMutableArray *array=[[NSMutableArray  alloc] initWithContentsOfFile:plistPath];  

  11.     self.provinces = array;  

  12.   

  13. }  


实现TableView表格部分,下面这些方法看方法名就能大概明白意思。

  •  这个方法用来告诉表格有几个分组

[cpp] view plaincopy

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

  2.     return [provinces count];  

  3. }  

  • 这个方法告诉表格第section个分段有多少行

[cpp] view plaincopy

  1. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {  

  2.         NSArray *cities = [[provinces objectAtIndex:section]objectForKey:@"Citys"];  

  3.     return [cities count];  

  4. }  

  •    这个方法用来告诉某个分组的某一行是什么数据,返回一个UITableViewCell

[cpp] view plaincopy

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

  2.     NSUInteger section = [indexPath section];   

  3.     NSUInteger row = [indexPath row];   

  4.       

  5.       

  6.     NSArray *cities = [[provinces objectAtIndex:section]objectForKey:@"Citys"] ;  

  7.       

  8.       

  9.     static NSString *GroupedTableIdentifier = @"cell";   

  10.     UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:   

  11.                              GroupedTableIdentifier];   

  12.     if (cell == nil) {   

  13.         cell = [[UITableViewCell alloc]   

  14.                 initWithStyle:UITableViewCellStyleDefault   

  15.                 reuseIdentifier:GroupedTableIdentifier];   

  16.     }   

  17.       

  18.     //给Label附上城市名称  key 为:C_Name  

  19.     cell.textLabel.text = [[cities objectAtIndex:row] objectForKey:@"C_Name"];   

  20.     return cell;   

  21. }  

  • 这个方法用来告诉表格第section分组的名称 

[cpp] view plaincopy

  1. - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section {  

  2.     NSString *provincName = [[provinces objectAtIndex:section] objectForKey:@"p_Name"];  

  3.     return provincName;   

  4. }  



  • 重点介绍下这个方法:

[cpp] view plaincopy

  1. - (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {  

  2.     //返回省份的数组  

  3.     NSMutableArray *array = [NSMutableArray arrayWithCapacity:35];  

  4.     for (NSDictionary *dict in provinces) {  

  5.         [array addObject:[dict objectForKey:@"p_Name"]];  

  6.     }  

  7.     return array;  

  8. }  

返回所有省份名称的数组 ,通过点击右边的省份名称能快速定位到这个省份的城市,也就是快速定位到这个section。

OK,运行。效果如下:



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



以上例子的全部


例子的代码:http://download.csdn.net/detail/totogo2010/4361876

https://github.com/schelling/YcDemo/tree/master/TableViewGrouped

著作权声明:本文由http://blog.csdn.net/totogo2010/原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢!


© 著作权归作者所有

共有 人打赏支持
粉丝 1
博文 17
码字总数 12485
作品 0
广州
修复ios不支持fixed属性

场景说明:产品需求在wap页面,需要在页面底部固定一块区域执行输入操作。在Android手机中,对position:fixed是完美支持并实现预计效果的,但ios系统手机测试时出现输入框光标不居中和底部区...

碌星 ⋅ 05/19 ⋅ 0

Table View Programming Guide for iOS 官方文档翻译

About Table Views in iOS Apps( iOS应用程序中的Table View) Table views are versatile user interface objects frequently found in iOS apps. A table view presents data in a scrol......

zyq522376829 ⋅ 05/03 ⋅ 0

UISegmentedControl segmentedControl

一、简介 <UIControl-->UIView-->UIResponder-->NSObject 格式为 1-->初始化(作用) typedef NS_OPTIONS(NSUInteger, UIDataDetectorTypes) { UIDataDetector......

无邪8 ⋅ 05/22 ⋅ 0

常见的移动端H5页面开发遇到的坑和解决办法

手机共通问题 问题一:用同等比例的图片在PC机上很清楚,但是手机上很模糊,原因是什么呢? 经研究发现是devicePixelRatio作怪,因为手机分辨率太小,如果按照分辨率来显示网页字会非常小,所以苹果...

webmirror ⋅ 05/02 ⋅ 0

如何判断你是合格的高级iOS开发工程师?

前言 随着移动互联网的高速发展泄洪而来,有意学习移动开发的人越来越多了,竞争也是越来越大,需要学习的东西很多。如何才能在激烈的移动开发者竞争中一枝独秀,成为一名真正合格的高级iOS...

_小迷糊 ⋅ 05/26 ⋅ 0

iOS原生混合RN开发最佳实践

做过原生iOS开发或者Android开发的同学们肯定也都了解Hybrid,有一些Hybrid的开发经验,目前我们企业开发中运用最广泛的Hybrid App技术就是原生与H5 hybrid,在早期的时候,可能部分同学也接...

光强 ⋅ 05/16 ⋅ 0

2018 一份"有点难"的iOS面试题(5年iOS开发)

序言: 之前一时兴致在本站上出过一份iOS的中级面试题,引起一些关注,不少同学表示对”隐藏关卡“感兴趣。升级版iOS面试题来了,目测难倒90%iOS程序员,目测一大波程序员撸着袖子在靠近。 ...

原来是泽镜啊 ⋅ 05/26 ⋅ 0

面试官自述:面向高级开发人员的iOS面试问题

当您准备进行技术性iOS面试时,了解您可能会询问哪些主题以及经验丰富的iOS开发人员期望什么是非常重要的。 这是许多硅谷公司用来衡量iOS候选人资历水平的一系列问题。 这些问题涉及iOS开发的...

菇哒微课 ⋅ 04/26 ⋅ 0

【AR】开始使用Vuforia开发iOS(2)

原 设置iOS开发环境 安装Vuforia iOS SDK 如何安装Vuforia iOS示例 编译并运行Vuforia iOS示例 支持iOS金属 iOS 64位迁移 设置iOS开发环境 适用于iOS的Vuforia引擎目前支持运行iOS 9及更高版...

lichong951 ⋅ 06/11 ⋅ 0

iOS自定义弹出视图、收音机APP、图片涂鸦、加载刷新、文件缓存等源码

iOS精选源码 一款优秀的 聆听夜空FM 源码(http://www.code4app.com/thread-14546-1-1.html) zhPopupController 简单快捷弹出自定义视图(http://www.code4app.com/thread-14861-1-1.html) WHS......

sunnyaigd ⋅ 06/04 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

UI ,前端框架选型

Flat-UI

miaojiangmin ⋅ 4分钟前 ⋅ 0

Istio Service Mesh 教程

Istio Service Mesh 教程 作者 宋净超 | 5400字 | 阅读大约需要11分钟 | 归档于istio | 发表于 2018-05-22 标签 #Istio #教程,来自 https://servicemesher.github.io/blog/istio-service-m...

openthings ⋅ 9分钟前 ⋅ 0

scala swing

scala swing组件的库 https://github.com/scala/scala-swing scala swing的API文档 https://www.scala-lang.org/api/2.9.1/scala/swing/package.html...

whoisliang ⋅ 13分钟前 ⋅ 0

CentOS安装配置Nginx

安装依赖 yum install gcc yum install pcre-devel yum install zlib zlib-devel yum install openssl openssl-devel //一键安装上面四个依赖 yum -y install gcc zlib zlib-devel pcre-deve......

临江仙卜算子 ⋅ 20分钟前 ⋅ 0

开源 java CMS - FreeCMS2.8 依申请公开

项目地址:http://www.freeteam.cn/ 依申请公开 1. 转交申请公开 用户可以把申请公开转交给其他人办理,系统会记录此申请公开的转交记录。 注意:同时只能转交一个申请公开。 选择需要转交的...

freeteam ⋅ 24分钟前 ⋅ 0

以太坊 web3.py 签名转账

以太坊 web3.py 签名转账 本文节选自电子书《Netkiller Blockchain 手札》 Netkiller Blockchain 手札 Mr. Neo Chan, 陈景峯(BG7NYT) 中国广东省深圳市龙华新区民治街道溪山美地 518131 +86...

netkiller- ⋅ 29分钟前 ⋅ 0

年薪40W的程序员必会的技术有哪些?

很多人在问我,程序员如何拿高薪,如何做到年薪40W+,其实总结出来还是一句话,你的技术决定你的能力已经薪资。 那么什么样的技术人才才能拿到一份Java行业里面的高薪呢? 下面是我的一个总结...

码代码的小司机 ⋅ 30分钟前 ⋅ 0

jesque-spring使用及源码分析

1.使用 jesque结合spring使用,步骤如下: 1.1 在项目中添加maven依赖 <dependency> <groupId>net.lariverosc</groupId> <artifactId>jesque-spring</artifactId> <version>1.0.0</ve......

Funcy1122 ⋅ 31分钟前 ⋅ 0

OSChina 周二乱弹 —— 加班的代码不要枉费了我的童子功

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @小小编辑:推荐歌曲《29》- 未完成乐队 《29》- 未完成乐队 手机党少年们想听歌,请使劲儿戳(这里) @FalconChen :#看球提醒# 02:00 巴西v...

小小编辑 ⋅ 57分钟前 ⋅ 16

Docker Swarm的前世今生

概述 在我的《Docker Swarm集群初探》一文中,我们实际体验了Docker Swarm容器集群技术的魅力,与《Kubernetes实践录》一文中提到的Kubernetes集群技术相比,Docker Swarm没有Kubernetes显得...

CodeSheep ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部