一、基本介绍

在众多移动应⽤用中,能看到各式各样的表格数据 。

在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView,UITableView继承自UIScrollView,因此支持垂直滚动,⽽且性能极佳 。

UITableview有分组和不分组两种样式,可以在storyboard或者是用代码设置。

二、数据展示

UITableView需要⼀一个数据源(dataSource)来显示数据

UITableView会向数据源查询一共有多少行数据以及每⼀行显示什么数据等

没有设置数据源的UITableView只是个空壳

凡是遵守UITableViewDataSource协议的OC对象,都可以是UITableView的数据源

展示数据的过程:

(1)调用数据源的下面⽅法得知⼀一共有多少组数据

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;

(2)调用数据源的下面⽅法得知每一组有多少行数据

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section;

(3)调⽤数据源的下⾯⽅法得知每⼀⾏显示什么内容

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;

三、代码示例

(1)能基本展示的“垃圾”代码

复制代码

1 #import "NJViewController.h"

2

3 @interface NJViewController ()

4 @property (weak, nonatomic) IBOutlet UITableView *tableView;

5

6 @end

7

8 @implementation NJViewController

9

10 - (void)viewDidLoad

11 {

12 [super viewDidLoad];

13 // 设置tableView的数据源

14 self.tableView.dataSource = self;

15

}

17

#pragma mark - UITableViewDataSource

19 /**

20 * 1.告诉tableview一共有多少组

21 */

22 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView

23 {

24 NSLog(@"numberOfSectionsInTableView");

25 return 2;

26 }

27 /**

28 * 2.第section组有多少行

29 */

30 - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section

31 {

32 NSLog(@"numberOfRowsInSection %d", section);

33 if (0 == section) {

34 // 第0组有多少行

35 return 2;

36 }else

37 {

38 // 第1组有多少行

39 return 3;

40 }

41 }

42 /**

43 * 3.告知系统每一行显示什么内容

44 */

45 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

46 {

47 NSLog(@"cellForRowAtIndexPath %d %d", indexPath.section, indexPath.row);

48 // indexPath.section; // 第几组

49 // indexPath.row; // 第几行

50 // 1.创建cell

51 UITableViewCell *cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];

52

53 // 2.设置数据

54 // cell.textLabel.text = @"汽车";

55 // 判断是第几组的第几行

56 if (0 == indexPath.section) { // 第0组

57 if (0 == indexPath.row) // 第0组第0行

58 {

59 cell.textLabel.text = @"奥迪";

60 }else if (1 == indexPath.row) // 第0组第1行

61 {

62 cell.textLabel.text = @"宝马";

63 }

64

65 }else if (1 == indexPath.section) // 第1组

66 {

67 if (0 == indexPath.row) { // 第0组第0行

68 cell.textLabel.text = @"本田";

69 }else if (1 == indexPath.row) // 第0组第1行

70 {

71 cell.textLabel.text = @"丰田";

72 }else if (2 == indexPath.row) // 第0组第2行

73 {

74 cell.textLabel.text = @"马自达";

75 }

76 }

77

78 // 3.返回要显示的控件

79 return cell;

80

81 }

82 /**

83 * 第section组头部显示什么标题

84 *

85 */

86 - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section

87 {

88 // return @"标题";

89 if (0 == section) {

90 return @"德系品牌";

91 }else

92 {

93 return @"日韩品牌";

94 }

95 }

96 /**

97 * 第section组底部显示什么标题

98 *

99 */

100 - (NSString *)tableView:(UITableView *)tableView titleForFooterInSection:(NSInteger)section

101 {

102 if (0 == section) {

103 return @"高端大气上档次";

104 }else

105 {

106 return @"还不错";

107 }

108 }

109 @end

(2)让代码的数据独立

新建一个模型

1 #import

2

3 @interface NJCarGroup : NSObject

4 /**

5 * 标题

6 */

7 @property (nonatomic, copy) NSString *title;

8 /**

9 * 描述

10 */

11 @property (nonatomic, copy) NSString *desc;

12 /**

13 * 当前组所有行的数据

14 */

15 @property (nonatomic, strong) NSArray *cars;

16

17 @end

1 #import "NJViewController.h"

2 #import "NJCarGroup.h"

3

4 @interface NJViewController ()

5 @property (weak, nonatomic) IBOutlet UITableView *tableView;

6 /**

7 * 保存所有组的数据(其中每一元素都是一个模型对象)

8 */

9 @property (nonatomic, strong) NSArray *carGroups;

10 @end

11

12

13 @implementation NJViewController

14

15

16 #pragma mark - 懒加载

17 - (NSArray *)carGroups

18 {

19 if (_carGroups == nil) {

20 // 1.创建模型

21 NJCarGroup *cg1 = [[NJCarGroup alloc] init];

22 cg1.title = @"德系品牌";

23 cg1.desc = @"高端大气上档次";

24 cg1.cars = @[@"奥迪", @"宝马"];

25

26 NJCarGroup *cg2 = [[NJCarGroup alloc] init];

27 cg2.title = @"日韩品牌";

28 cg2.desc = @"还不错";

29 cg2.cars = @[@"本田", @"丰田", @"小田田"];

30

31 NJCarGroup *cg3 = [[NJCarGroup alloc] init];

32 cg3.title = @"欧美品牌";

33 cg3.desc = @"价格昂贵";

34 cg3.cars = @[@"劳斯莱斯", @"布加迪", @"小米"];

35 // 2.将模型添加到数组中

36 _carGroups = @[cg1, cg2, cg3];

37 }

38 // 3.返回数组

39 return _carGroups;

40 }

41

42 - (void)viewDidLoad

43 {

44 [super viewDidLoad];

45 // 设置tableView的数据源

46 self.tableView.dataSource = self;

47

48 }

49

50 #pragma mark - UITableViewDataSource

51 /**

52 * 1.告诉tableview一共有多少组

53 */

54 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView

55 {

56 NSLog(@"numberOfSectionsInTableView");

57 return self.carGroups.count;

58 }

59 /**

60 * 2.第section组有多少行

61 */

62 - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section

63 {

64 NSLog(@"numberOfRowsInSection %d", section);

65 // 1.取出对应的组模型

66 NJCarGroup *g = self.carGroups[section];

67 // 2.返回对应组的行数

68 return g.cars.count;

}

70 /**

71 * 3.告知系统每一行显示什么内容

72 */

73 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

74 {

75 NSLog(@"cellForRowAtIndexPath %d %d", indexPath.section, indexPath.row);

76 // indexPath.section; // 第几组

77 // indexPath.row; // 第几行

78 // 1.创建cell

79 UITableViewCell *cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:nil];

80

81 // 2.设置数据

82 // cell.textLabel.text = @"嗨喽";

83 // 2.1取出对应组的模型

84 NJCarGroup *g = self.carGroups[indexPath.section];

85 // 2.2取出对应行的数据

86 NSString *name = g.cars[indexPath.row];

87 // 2.3设置cell要显示的数据

88 cell.textLabel.text = name;

89 // 3.返回要显示的控件

90 return cell;

91

92 }

93 /**

94 * 第section组头部显示什么标题

95 *

96 */

97 - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section

98 {

99 // return @"标题";

100 // 1.取出对应的组模型

101 NJCarGroup *g = self.carGroups[section];

102 return g.title;

103 }

104 /**

105 * 第section组底部显示什么标题

106 *

107 */

108 - (NSString *)tableView:(UITableView *)tableView titleForFooterInSection:(NSInteger)section

109 {

110 // return @"标题";

111 // 1.取出对应的组模型

112 NJCarGroup *g = self.carGroups[section];

113 return g.desc;

114 }

115 @end

提示:请自行体会把数据独立出来单独处理,作为数据模型的好处。另外,把什么抽成一个模型,一定要弄清楚。

四、补充点

contentView下默认有3个⼦视图

第2个是UILabel(通过UITableViewCell的textLabel和detailTextLabel属性访问)

第3个是UIImageView(通过UITableViewCell的imageView属性访问)

UITableViewCell还有⼀个UITableViewCellStyle属性,⽤于决定使用contentView的哪些子视图,以及这些子视图在contentView中的位置

UI篇—UITableview的更多相关文章

  1. iOS开发UI篇—UITableview控件简单介绍

    iOS开发UI篇—UITableview控件简单介绍 一.基本介绍 在众多移动应⽤用中,能看到各式各样的表格数据 . 在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView,UIT ...

  2. iOS开发UI篇—UITableview控件基本使用

    iOS开发UI篇—UITableview控件基本使用 一.一个简单的英雄展示程序 NJHero.h文件代码(字典转模型) #import <Foundation/Foundation.h> ...

  3. iOS开发UI篇—UITableview控件使用小结

    iOS开发UI篇—UITableview控件使用小结 一.UITableview的使用步骤 UITableview的使用就只有简单的三个步骤: 1.告诉一共有多少组数据 方法:- (NSInteger ...

  4. iOS开发UI篇—实现UItableview控件数据刷新

    iOS开发UI篇—实现UItableview控件数据刷新 一.项目文件结构和plist文件 二.实现效果 1.说明:这是一个英雄展示界面,点击选中行,可以修改改行英雄的名称(完成数据刷新的操作). 运 ...

  5. iOS开发UI篇—使用UItableview完成一个简单的QQ好友列表(一)

    iOS开发UI篇—使用UItableview完成一个简单的QQ好友列表(一) 一.项目结构和plist文件 二.实现代码 1.说明: 主控制器直接继承UITableViewController // ...

  6. iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建

    iOS开发UI篇—在UITableview的应用中使用动态单元格来完成app应用程序管理界面的搭建 一.实现效果 说明:该示例在storyboard中使用动态单元格来完成. 二.实现 1.项目文件结构 ...

  7. iOS开发UI篇—直接使用UITableView Controller

    iOS开发UI篇—直接使用UITableView Controller 一.一般过程 // // YYViewController.h // UITableView Controller // // ...

  8. ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布局

    本文转自 :http://www.cnblogs.com/wendingding/p/3761730.html ios开发UI篇—使用纯代码自定义UItableviewcell实现一个简单的微博界面布 ...

  9. iOS开发UI篇—UITableviewcell的性能优化和缓存机制

    iOS开发UI篇—UITableviewcell的性能问题 一.UITableviewcell的一些介绍 UITableView的每一行都是一个UITableViewCell,通过dataSource ...

随机推荐

  1. datatables.js 里面遇到的问题

    1. 假如需要A行的data 和 B行的data 合并 在B行 data:name 在A行的 render:function(){ return data+full.name   此时返回的就是A+B ...

  2. util:properties与context:property-placeholder

    spring 使用注解装配的Bean如何使用property-placeholder属性配置中的值 这个问题不大不小,以前偷懒凡是碰到需要引用属性文件中的类时就改用xml来配置. 今天看了下sprin ...

  3. Struct和Class的区别(转载)

    转载来源:http://blog.sina.com.cn/s/blog_48f587a80100k630.html C++中的struct对C中的struct进行了扩充,它已经不再只是一个包含不同数据 ...

  4. redis安装以及远程连接

    第一步下载: Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases. 第二步: 运行安装 记录安装路径 C:\Program Fil ...

  5. jquery选择器之基本筛选选择

    1.基本选择器 2.内容筛选选择器 3.可见性筛选选择器 4.属性筛选选择器 5.子元素筛选选择器 6.表单元素选择器 7.表单对象属性筛选器

  6. 《Windows编程循序渐进》——进度条

    界面布局如下:

  7. 用户代理检测与浏览器Ua详细分析

    用户代理检测与浏览器Ua详细分析:http://www.cnblogs.com/hykun/p/Ua.html

  8. MySQL(3)-索引

    一.索引类型 在MySQL中,存储引擎使用索引,首先在索引中找到对应值,然后根据匹配的索引记录中找到对应的行. 无论是多么复杂的ORM工具,在精妙和复杂的索引面前都是"浮云".这里 ...

  9. Ambari安装组件出错

    Caught an exception while executing custom service command: <class 'ambari_agent.AgentException.A ...

  10. php 备份数据库

    <?php    header("Content-type:text/html;charset=utf-8");    //配置信息  $cfg_dbhost = 'loca ...