在 Objective-C 中,将 UITableView 的 delegate 和 dataSource 方法与 ViewController 分离,可以通过创建一个独立的类来实现。这种方法有助于提高代码的模块化和可维护性。以下是几种实现方式:
1. 创建独立的代理类
可以将 UITableViewDataSource 和 UITableViewDelegate 实现放在单独的类中,并在 ViewController 中将 UITableView 的代理设置为这个类。
实现步骤
1.1 创建独立的代理类
// TableViewHandler.h
#import <UIKit/UIKit.h>
@interface TableViewHandler : NSObject <UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, strong) NSArray *data;
@end
// TableViewHandler.m
#import "TableViewHandler.h"
@implementation TableViewHandler
#pragma mark - UITableViewDataSource
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return self.data.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"];
if (!cell) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"];
}
cell.textLabel.text = self.data[indexPath.row];
return cell;
}
#pragma mark - UITableViewDelegate
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
NSLog(@"Selected row: %@", self.data[indexPath.row]);
}
@end
1.2 在 ViewController 中使用这个代理类
// ViewController.m
#import "ViewController.h"
#import "TableViewHandler.h"
@interface ViewController ()
@property (nonatomic, strong) UITableView *tableView;
@property (nonatomic, strong) TableViewHandler *tableViewHandler;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// 初始化数据
NSArray *data = @[@"Item 1", @"Item 2", @"Item 3"];
self.tableViewHandler = [[TableViewHandler alloc] init];
self.tableViewHandler.data = data;
// 初始化 UITableView
self.tableView = [[UITableView alloc] initWithFrame:self.view.bounds style:UITableViewStylePlain];
self.tableView.dataSource = self.tableViewHandler;
self.tableView.delegate = self.tableViewHandler;
[self.view addSubview:self.tableView];
}
@end
2. 使用协议回调传递事件
如果需要在 ViewController 中处理某些事件(如点击事件),可以通过自定义协议进行回调。
实现步骤
2.1 定义协议
// TableViewHandler.h
#import <UIKit/UIKit.h>
@protocol TableViewHandlerDelegate <NSObject>
- (void)didSelectItem:(NSString *)item;
@end
@interface TableViewHandler : NSObject <UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, weak) id<TableViewHandlerDelegate> delegate;
@property (nonatomic, strong) NSArray *data;
@end
// TableViewHandler.m
#import "TableViewHandler.h"
@implementation TableViewHandler
#pragma mark - UITableViewDataSource
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return self.data.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"];
if (!cell) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"];
}
cell.textLabel.text = self.data[indexPath.row];
return cell;
}
#pragma mark - UITableViewDelegate
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
if ([self.delegate respondsToSelector:@selector(didSelectItem:)]) {
[self.delegate didSelectItem:self.data[indexPath.row]];
}
}
@end
2.2 在 ViewController 中实现协议
// ViewController.h
#import <UIKit/UIKit.h>
#import "TableViewHandler.h"
@interface ViewController : UIViewController <TableViewHandlerDelegate>
@end
// ViewController.m
#import "ViewController.h"
@interface ViewController ()
@property (nonatomic, strong) UITableView *tableView;
@property (nonatomic, strong) TableViewHandler *tableViewHandler;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// 初始化数据
NSArray *data = @[@"Item 1", @"Item 2", @"Item 3"];
self.tableViewHandler = [[TableViewHandler alloc] init];
self.tableViewHandler.data = data;
self.tableViewHandler.delegate = self;
// 初始化 UITableView
self.tableView = [[UITableView alloc] initWithFrame:self.view.bounds style:UITableViewStylePlain];
self.tableView.dataSource = self.tableViewHandler;
self.tableView.delegate = self.tableViewHandler;
[self.view addSubview:self.tableView];
}
#pragma mark - TableViewHandlerDelegate
- (void)didSelectItem:(NSString *)item {
NSLog(@"Selected item: %@", item);
}
@end
3. 使用 Block(闭包)进行回调
可以在 TableViewHandler 中定义 Block 来传递事件,减少协议的定义。
示例代码
3.1 在 TableViewHandler 中添加 Block
// TableViewHandler.h
#import <UIKit/UIKit.h>
typedef void(^DidSelectItemBlock)(NSString *item);
@interface TableViewHandler : NSObject <UITableViewDataSource, UITableViewDelegate>
@property (nonatomic, strong) NSArray *data;
@property (nonatomic, copy) DidSelectItemBlock didSelectItemBlock;
@end
// TableViewHandler.m
#import "TableViewHandler.h"
@implementation TableViewHandler
#pragma mark - UITableViewDataSource
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return self.data.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"];
if (!cell) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"Cell"];
}
cell.textLabel.text = self.data[indexPath.row];
return cell;
}
#pragma mark - UITableViewDelegate
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
if (self.didSelectItemBlock) {
self.didSelectItemBlock(self.data[indexPath.row]);
}
}
@end
3.2 在 ViewController 中设置 Block
// ViewController.m
#import "ViewController.h"
#import "TableViewHandler.h"
@interface ViewController ()
@property (nonatomic, strong) UITableView *tableView;
@property (nonatomic, strong) TableViewHandler *tableViewHandler;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// 初始化数据
NSArray *data = @[@"Item 1", @"Item 2", @"Item 3"];
self.tableViewHandler = [[TableViewHandler alloc] init];
self.tableViewHandler.data = data;
self.tableViewHandler.didSelectItemBlock = ^(NSString *item) {
NSLog(@"Selected item: %@", item);
};
// 初始化 UITableView
self.tableView = [[UITableView alloc] initWithFrame:self.view.bounds style:UITableViewStylePlain];
self.tableView.dataSource = self.tableViewHandler;
self.tableView.delegate = self.tableViewHandler;
[self.view addSubview:self.tableView];
}
@end
总结
• 独立代理类:适合简单列表逻辑。
• 协议回调:适合复杂的交互逻辑。
• Block 回调:语法简洁,适合快速开发。
根据需求选择合适的方式即可!