快速设置UITableView不同section对应于不同种类的cell
快速设置UITableView不同section对应于不同种类的cell

本文主要是为了写明如何在UITableView中,一个section对应于一种类型的cell,写起来不凌乱.
在不封装任何类的前提下提供如下源码:
请自行创建出3种类型的cell,创建好了就行,你需要创建出ModelOneCell,ModelTwoCell,ModelThreeCell,内容为空
//
// RootViewController.m
// Sections
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import "ModelOneCell.h"
#import "ModelTwoCell.h"
#import "ModelThreeCell.h" @interface RootViewController ()<UITableViewDelegate, UITableViewDataSource> @property (nonatomic, strong) UITableView *tableView; // tableView @property (nonatomic, strong) NSMutableArray *dataArray; // 数据数组
@property (nonatomic, strong) NSMutableArray *nameList; // 数组名字 @end @implementation RootViewController #pragma mark - 只初始化一次
#define REUESED_SIZE 100
static NSString *reUsedStr[REUESED_SIZE] = {nil}; // 重用标示
#define REUESED_FLAG reUsedStr[0]
+ (void)initialize
{
if (self == [RootViewController class])
{
for (int i = ; i < REUESED_SIZE; i++)
{
reUsedStr[i] = [NSString stringWithFormat:@"GoodBoy_%d", i];
}
}
} - (void)viewDidLoad
{
[super viewDidLoad]; // 初始化tableView
_tableView = [[UITableView alloc] initWithFrame:self.view.bounds
style:UITableViewStylePlain];
[self.view addSubview:_tableView];
_tableView.delegate = self;
_tableView.dataSource = self; // 模拟三种类型的数据源
NSArray *type1 = @[@"", @"", @""];
NSArray *type2 = @[@"一", @"二", @"三"];
NSArray *type3 = @[@"one", @"two", @"three"]; // 添加数据源 + 数据源标签名字
_dataArray = [NSMutableArray new];
_nameList = [NSMutableArray new];
[_dataArray addObject:type1]; [_nameList addObject:@"ModelOneCell"];
[_dataArray addObject:type2]; [_nameList addObject:@"ModelTwoCell"];
[_dataArray addObject:type3]; [_nameList addObject:@"ModelThreeCell"];
} #pragma mark - UITableView'delegate & dataSource
// 每个区有几个cell
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return [_dataArray[section] count];
} // 设定tableView有几个区域
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
return [_nameList count];
} // cell的初始化以及重用设置
-(UITableViewCell *)tableView:(UITableView *)tableView
cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 根据section区域获取几种cell的公共父类
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:reUsedStr[indexPath.section]]; // 根据不同的区域对应创建出该区域的cell
if (cell == nil)
{
if ([_nameList[indexPath.section] isEqualToString:@"ModelOneCell"])
{
cell = [[ModelOneCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
}
else if ([_nameList[indexPath.section] isEqualToString:@"ModelTwoCell"])
{
cell = [[ModelTwoCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
} else if ([_nameList[indexPath.section] isEqualToString:@"ModelThreeCell"])
{
cell = [[ModelThreeCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
}
} // 对cell进行设置
if ([_nameList[indexPath.section] isEqualToString:@"ModelOneCell"])
{
cell = [[ModelOneCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = _dataArray[indexPath.section][indexPath.row];
}
else if ([_nameList[indexPath.section] isEqualToString:@"ModelTwoCell"])
{
cell = [[ModelTwoCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = _dataArray[indexPath.section][indexPath.row];
} else if ([_nameList[indexPath.section] isEqualToString:@"ModelThreeCell"])
{
cell = [[ModelThreeCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = _dataArray[indexPath.section][indexPath.row];
} return cell;
} // 点击cell获取数据
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([_nameList[indexPath.section] isEqualToString:@"ModelOneCell"])
{
NSLog(@"%@", _dataArray[indexPath.section][indexPath.row]);
}
else if ([_nameList[indexPath.section] isEqualToString:@"ModelTwoCell"])
{
NSLog(@"%@", _dataArray[indexPath.section][indexPath.row]);
} else if ([_nameList[indexPath.section] isEqualToString:@"ModelThreeCell"])
{
NSLog(@"%@", _dataArray[indexPath.section][indexPath.row]);
}
} // 设定不同种类cell的高度
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([_nameList[indexPath.section] isEqualToString:@"ModelOneCell"])
{
return ;
}
else if ([_nameList[indexPath.section] isEqualToString:@"ModelTwoCell"])
{
return ;
} else if ([_nameList[indexPath.section] isEqualToString:@"ModelThreeCell"])
{
return ;
}
else
{
return ;
}
} @end
运行时候的效果如下:

核心思想:

接下来,我们就要来进行封装,达到好用的目的:)
我们把数据源以及数据源标签抽象成一个对象就可以很好的管理这些东西了,以下给出源码:
//
// TableVewData.h
// Sections
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h> @interface TableViewData : NSObject // 添加数据源 + 数据源标签
- (void)addDataArray:(NSArray *)array arrayFlag:(NSString *)flag; // 对应区域中的row的个数
- (NSInteger)numberOfRowsInSection:(NSInteger)section; // 有几个section
- (NSInteger)numberOfSections; // 对应于Section上的flag值标签
- (NSString *)flagInSection:(NSIndexPath *)indexPath; // 对应于indexPath中的数据
- (id)dataInIndexPath:(NSIndexPath *)indexPath; @end
//
// TableVewData.m
// Sections
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "TableViewData.h" @interface TableViewData () @property (nonatomic, strong) NSMutableArray *dataArray;
@property (nonatomic, strong) NSMutableArray *nameList; @end @implementation TableViewData - (instancetype)init
{
self = [super init];
if (self)
{
_dataArray = [NSMutableArray new];
_nameList = [NSMutableArray new];
}
return self;
} - (void)addDataArray:(NSArray *)array arrayFlag:(NSString *)flag
{
[_dataArray addObject:array];
[_nameList addObject:flag];
} - (NSInteger)numberOfRowsInSection:(NSInteger)section
{
return [_dataArray[section] count];
} - (NSInteger)numberOfSections
{
return [_dataArray count];
} - (NSString *)flagInSection:(NSIndexPath *)indexPath
{
return _nameList[indexPath.section];
} - (id)dataInIndexPath:(NSIndexPath *)indexPath
{
return _dataArray[indexPath.section][indexPath.row];
} @end
主函数使用情形如下:
//
// RootViewController.m
// Sections
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import "ModelOneCell.h"
#import "ModelTwoCell.h"
#import "ModelThreeCell.h" #import "TableViewData.h" @interface RootViewController ()<UITableViewDelegate, UITableViewDataSource> @property (nonatomic, strong) UITableView *tableView; // tableView @property (nonatomic, strong) TableViewData *tableData; @end @implementation RootViewController #pragma mark - 只初始化一次
#define REUESED_SIZE 100
static NSString *reUsedStr[REUESED_SIZE] = {nil}; // 重用标示
#define REUESED_FLAG reUsedStr[0]
+ (void)initialize
{
if (self == [RootViewController class])
{
for (int i = ; i < REUESED_SIZE; i++)
{
reUsedStr[i] = [NSString stringWithFormat:@"GoodBoy_%d", i];
}
}
} - (void)viewDidLoad
{
[super viewDidLoad]; // 初始化tableView
_tableView = [[UITableView alloc] initWithFrame:self.view.bounds
style:UITableViewStylePlain];
[self.view addSubview:_tableView];
_tableView.delegate = self;
_tableView.dataSource = self; // 模拟三种类型的数据源
NSArray *type1 = @[@"", @"", @""];
NSArray *type2 = @[@"一", @"二", @"三"];
NSArray *type3 = @[@"one", @"two", @"three"]; // 添加数据源 + 数据源标签名字
_tableData = [TableViewData new];
[_tableData addDataArray:type1 arrayFlag:@"ModelOneCell"];
[_tableData addDataArray:type2 arrayFlag:@"ModelTwoCell"];
[_tableData addDataArray:type3 arrayFlag:@"ModelThreeCell"];
} #pragma mark - UITableView'delegate & dataSource
// 每个区有几个cell
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return [_tableData numberOfRowsInSection:section];
} // 设定tableView有几个区域
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
return [_tableData numberOfSections];
} // cell的初始化以及重用设置
-(UITableViewCell *)tableView:(UITableView *)tableView
cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
// 根据section区域获取几种cell的公共父类
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:reUsedStr[indexPath.section]]; // 根据不同的区域对应创建出该区域的cell
if (cell == nil)
{
if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelOneCell"])
{
cell = [[ModelOneCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
}
else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelTwoCell"])
{
cell = [[ModelTwoCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
} else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelThreeCell"])
{
cell = [[ModelThreeCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
}
} // 对cell进行设置
if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelOneCell"])
{
cell = [[ModelOneCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = [_tableData dataInIndexPath:indexPath];
}
else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelTwoCell"])
{
cell = [[ModelTwoCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = [_tableData dataInIndexPath:indexPath];
} else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelThreeCell"])
{
cell = [[ModelThreeCell alloc] initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:reUsedStr[indexPath.section]];
cell.textLabel.text = [_tableData dataInIndexPath:indexPath];
} return cell;
} // 点击cell获取数据
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelOneCell"])
{
NSLog(@"%@", [_tableData dataInIndexPath:indexPath]);
}
else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelTwoCell"])
{
NSLog(@"%@", [_tableData dataInIndexPath:indexPath]);
} else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelThreeCell"])
{
NSLog(@"%@", [_tableData dataInIndexPath:indexPath]);
}
} // 设定不同种类cell的高度
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelOneCell"])
{
return ;
}
else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelTwoCell"])
{
return ;
} else if ([[_tableData flagInSection:indexPath] isEqualToString:@"ModelThreeCell"])
{
return ;
}
else
{
return ;
}
} @end
添加数据源:

见名知意:

使用很便利:


快速设置UITableView不同section对应于不同种类的cell的更多相关文章
- collectionView代理方法快速设置cell大小上下左右间隔
#define JianGe 25 #define GeShu 4 #define ScreenWidth ([UIScreen mainScreen].bounds.size.width) #def ...
- [Xcode 实际操作]五、使用表格-(5)设置UITableView的单元格背景颜色
目录:[Swift]Xcode实际操作 本文将演示单元格背景颜色的设置 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit //首先添加两个协 ...
- [Xcode 实际操作]五、使用表格-(4)设置UITableView单元格数据库源
目录:[Swift]Xcode实际操作 本文将演示如何自定义表格的数据来源. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit //首先添加 ...
- [Xcode 实际操作]五、使用表格-(3)设置UITableView单元格图标
目录:[Swift]Xcode实际操作 本文将演示如何给表格行设置图标. 打开资源文件夹[Assets.xcassets], 在资源文件夹中导入两张图片:一张彩色,一张灰色,作为单元格的图标. [+] ...
- [Xcode 实际操作]五、使用表格-(2)设置UITableView单元格高度
目录:[Swift]Xcode实际操作 本文将演示如何制作一个自定义行高的表格视图 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit //首 ...
- 设置UITableView的separatorInset值为UIEdgeInsetsZero,分隔线不最左端显示的问题
一.问题描述 UITableView分割线要显示到最左端 查看UITableView的属性,发现设置separatorInset的值可以自定义分割线的位置. @property (nonatomic) ...
- 分享一个快速设置背景的js 自动获取背景图的长宽
我来分享一个快速设置背景的js (需要jq支持!) 快速切图铺页面用---就是不需要手动输入背景图的长宽 自动获取背景图的长宽 : <div class="wrap"> ...
- 设置UITableView背景透明/监听cell左边的删除按钮的点击事件
_tableView = [[UITableView alloc] init]; _tableView.delegate = self; _tableView.dataSource = self; _ ...
- 【大盛】HTC one/M7 ROM 最新本地化OrDroid8.2.6 高级、快速设置 永久root 更多自定义 稳定 流畅
了解更多:点击下载ROM和学习更多 ROM版本 HTC-one_OrDroid8.2.6 ROM作者 雪狼团队·大盛 http://weibo.com/DaShengdd Android版本 Andr ...
随机推荐
- a+b+c的N次方展开
今天在给儿子看笔记本上的照片的时候,偶然发现了2009年手绘的一张a+b+c的N次方展开图,故写下面的博客以记之,为年轻时代的我点个赞! 20年前的我,一个充满激情的且富有专注力的数学发烧友! 10年 ...
- linux 段页式内存管理
http://blog.chinaunix.net/uid-24227137-id-3723898.html 页是信息的物理单位,分页是为了实现离散分配方式,以消减内存的外零头,提高内存的利用率从:或 ...
- ARM和X86架构
重温下CPU是什么 中央处理单元(CPU)主要由运算器.控制器.寄存器三部分组成.运算器起着运算的作用,控制器负责发出CPU每条指令所需要的信息,寄存器保存运算或者指令的一些临时文件以保证更高的速度. ...
- Java大法之面向对象
总觉得要写点东西,写写自己对知识的理解,对自己学的东西是否编程自己的了.我在想,如果让自己用自己的语言来解释,什么是面向对象,我可能会愣一下,我问自己什么是面向对象的时候,我想了想,自言自语说:面向对 ...
- i.mx6 Android5.1.1 System server
1. 概述: 1. Zygote进程是Android Java世界的开创者,所有的Java应用程序进程都由Zygote进程创建: 2. Zygote创建应用程序进程过程其实就是复制自身进程地址空间作为 ...
- laravel数据迁移的时候遇到的字符串长度的问题
问题截图: 问题解决办法: use Illuminate\Support\facades\Schema; Schema::defaultStringLength(191); ...
- iOS开源项目周报0316
由OpenDigg 出品的iOS开源项目周报第十二期来啦.我们的iOS开源周报集合了OpenDigg一周来新收录的优质的iOS开源项目,方便iOS开发人员便捷的找到自己需要的项目工具等.GodEye ...
- LightningChart 客户案例分享-DCC 环境工程
DCC Dynamics 致力于为建筑管控行业生产OEM的监控和管理产品.公司的旗舰产品“环境物流系统Environmental Logistics System” 用于大型建筑,校园及研究所设施,有 ...
- 使用k8s创建容器一直处于ContainerCreating状态
容器报错信息为(两种): FailedSynError syncing pod, skipping: failed to {kubelet 127.0.0.1} Warning FailedSync ...
- Knockout.js Attr绑定
<head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8&quo ...