iOS表视图UITableView之基础篇(二)

如果对UITableView的相关属性和协议还存在疑问,请先阅读我上一篇文章 iOS表视图UITableView之基础篇(一)


UITableViewController

  • 特点:
  1. UITableViewController继承于UIViewController,自带一个tableView
  1. UITableViewController中,self.viewself.tableView是同一个对象。
  2. datasourcedelegate默认都是self(UITableViewController)
  3. 开发中只需要建立UITableViewController

UITableView编辑

首先,在ViewController.m写出它的Extension(延展),方便下面代码的使用:

@interface ViewController ()<UITableViewDelegate, UITableViewDataSource>
@property (nonatomic, retain) UITableView *tableView;   /** 表视图 */
@property (nonatomic, retain) NSMutableArray *dataSource;   /** 数据源数组 */
@property (nonatomic, retain) NSMutableArray *deleteIndexPathsArray;   /** 将要删除的元素的indexPath */
@end
  • UITableView编辑步骤如下:
    一、让UITableView处于编辑状态:
    - (void)setEditing:(BOOL)editing animated:(BOOL)animated
    {
    //先执行父类的setEditing方法:
    [super setEditing:editing animated:animated];
    //(1)让tableView处于可编辑状态:
    [self.tableView setEditing:editing animated:animated];
    }
    二、协议设定
    1.确定Cell是否处于编辑状态:
    - (BOOL)tableView:(UITableView )tableView canEditRowAtIndexPath:(NSIndexPath )indexPath
    {
    //根据数据源进行筛选:
    NSString name = [[self.dataSource objectAtIndex:indexPath.row] valueForKey:@"name"];
    if ([name isEqualToString:@"张伟"]) {
    return NO; //如果有名字叫张伟的同学,那个cell就不可编辑
    }
    return YES; //(2)所有都可以编辑
    }
    2.设定Cell
    编辑样式
    删除/添加):
    - (UITableViewCellEditingStyle)tableView:(UITableView )tableView editingStyleForRowAtIndexPath:(NSIndexPath )indexPath
    {
    //(3)设置支持删除操作:
    // return UITableViewCellEditingStyleDelete;
    //设置插入操作:
    return UITableViewCellEditingStyleInsert;
    }
    3.编辑状态进行
    提交
    *:
    - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath
    {
    //判断编辑的样式:
    if (editingStyle == UITableViewCellEditingStyleDelete) {
    //删除对应的元素:
    [self.dataSource removeObjectAtIndex:indexPath.row];
    //刷新tableView:
    [tableView reloadData];
    }
    //判断是插入操作:
    if (editingStyle == UITableViewCellEditingStyleInsert) {
    //设置要插入的数据:
    NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:@"dog", @"name", nil];
    //将字典插入到数组的指定位置:
    [self.dataSource insertObject:dic atIndex:indexPath.row];
    //更新视图:
    [tableView reloadData];
    }
    }

*** 注意:***
编辑结束后,由于numberOfRowInSection这个协议tableview添加到父视图的时候走一次, 且table上的数据都是由数组提供,因此,需要先将数组中的元素删除,然后让table的协议重新走一遍进行重新赋值。 即:先修改数据源,再刷新table(如上,使用reloadData方法) 。

  • 移动cell的位置:
    1.实现delegate协议,告诉tableView是否能移动:
    - (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath
    {
    return YES;
    }
    2.移动:
    - (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath
    {
    //记录原来的下标和新的下标:
    NSInteger fromIndex = sourceIndexPath.row;
    NSInteger toIndex = destinationIndexPath.row;
    //记录数组元素:
    NSDictionary *dic = [[self.dataSource objectAtIndex:fromIndex] retain];
    //从数组中删除该元素:
    [self.dataSource removeObject:dic];
    //插入到新的位置:
    [self.dataSource insertObject:dic atIndex:toIndex];
    //更新视图:
    [tableView reloadData];
    }

  • 实现dataSource协议方法:

    #pragma mark --cell行数:
    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
    {
       return self.dataSource.count;
    }
    #pragma mark --cell的内容:
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
    {
       UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"myCell"];
       cell.textLabel.text = [[self.dataSource objectAtIndex:indexPath.row] valueForKey:@"name"];
       //判断是否正在被选中:(防止重用)
       if (![self.deleteIndexPathsArray containsObject:indexPath]) {
           cell.accessoryType = UITableViewCellAccessoryNone;
       }
       else
       {
           cell.accessoryType = UITableViewCellAccessoryCheckmark;
       }
       return cell;
    }
    #pragma mark --cell的高度:
    - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
    {
       return 80;
    }
    #pragma mark --cell的点击方法:
    - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
    {
       //根据indexPath找到对应的cell:
       UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
       //判断数组里是否包含该indexPath:
       if ([self.deleteIndexPathsArray containsObject:indexPath]) {
           [self.deleteIndexPathsArray removeObject:indexPath];
           //取消点击状态:
           cell.accessoryType = UITableViewCellAccessoryNone;
       }
       else
       {
           [self.deleteIndexPathsArray addObject:indexPath];
           cell.accessoryType = UITableViewCellAccessoryCheckmark;
       }
    }
    

以上内容是笔者对UITableView基础的总结。由于笔者也是iOS初学者,总结过程中难免出现纰漏。如发现不足或错误,欢迎批评指正。大家共同学习!共同进步!

有关UITableViewiOS的更多知识,请关注小编,期待后续文章!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容