用代码写静态表格

早期第一次接触StoryBoard的时候,就被其中一个控件吸引了,那就是静态表格。通过可视界面,将tableview里面的cell设置上不同的内容和属性,就像在添加简单的UIView一样简单。不同再去一个个写tableview的delegate、dataSource数据源设置,方便又简单。归结到底就是用最简单的方式去写UITableView,抛开他的delegate。

思路整理

首先需要通过代码的方式来实现,同时需要有复用功能,将delegate改用block来实现。简单的插入、删除、修改功能都应该有。

实现

思路有了,实现起来就简单了,为了更好的让大家使用,我已经将其push到github上。大家可以通过pod方式来添加:

pod "YStaticContentTableView"

示例

添加section和cell

这个一个添加section和cell到你的UITableView上的简单例子,需要把你的代码写在控制器的,viewDidLoad方法里。把tableView开启静态表格模式[self.tableView enableStaticTableView],

这里你可能需要引入头文件YStaticContentTableView.h。你可以和平时一样配置UITableViewCell,当然我们也提供YStaticContentTableViewCell对象来设置Cell的样式和复用ID。

YStaticContentTableViewSection允许你来设置诸如Section标题等。

正如你看到的我们还有一个不错的whenSelectedblock,这允许去写一些代码当我们点击cell时去运行,一个好的例子比如:push 一个 UIViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    [self.tableView enableStaticTableView];

    __weak typeof(self) weakSelf = self;
    [self.tableView addSection:^(YStaticContentTableViewSection *section, NSUInteger sectionIndex) {
        [section addCell:^(YStaticContentTableViewCell *staticContentCell, UITableViewCell *cell, NSIndexPath *indexPath) {
            staticContentCell.reuseIdentifier = @"UIControlCell";
            staticContentCell.tableViewCellSubclass = [YCustomCell class];

            YCustomCell *customCell = (YCustomCell *)cell;
            [customCell.btn setTitle:[NSString stringWithFormat:@"cell - %zd",i] forState:UIControlStateNormal];
            [customCell.btn addTarget:weakSelf action:@selector(btnClick) forControlEvents:UIControlEventTouchUpInside];
            [customCell.btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];/
        } whenSelected:^(NSIndexPath *indexPath) {
            [[[UIAlertView alloc] initWithTitle:@"提示" message:[NSString stringWithFormat:@"click - %zd",indexPath.row] delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil] show];
            [weakSelf.tableView deselectRowAtIndexPath:indexPath animated:YES];
        }];
    }];
}

运行时,插入一个Cell

这个行为就像addCell:除了这些,你还可以加上是否需要动画的设置

[self.tableView insertCell:^(YStaticContentTableViewCell *staticContentCell, UITableViewCell *cell, NSIndexPath *indexPath) {
    //config cell
} whenSelected:^(NSIndexPath *indexPath) {
    //TODO
} atIndexPath:[NSIndexPath indexPathForRow:0 inSection:0] animated:YES];

运行时,插入多个Cell

和上面一样,除了这些我们需要把我们的代码放在beginUpdates和endUpdates,然后保留我们所有UITableView的构建方式,而且还是使用不错,方便的语法。

[self.tableView beginUpdates];

for (NSInteger i = 0; i < 99; i++) {
    [self.tableView insertCell:^(YStaticContentTableViewCell *staticContentCell, UITableViewCell *cell, NSIndexPath *indexPath) {
        //config cell
    } whenSelected:^(NSIndexPath *indexPath) {
        //TODO
    } atIndexPath:[NSIndexPath indexPathForRow:0 inSection:0] animated:YES];
}

[self.tableView endUpdates];

总结

通过这种方式实现UITableView,会发现代码更易理解和维护了。

其它

github: https://github.com/LiZunYuan/YStaticContentTableView

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » 用代码写静态表格

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址