TableViewController不得不执行的那些方法

首先,我们继承于父类的 UIViewController 已经遵守了 <UITableViewDelegate, UITableViewDataSource>这两个协议。

在我们用到这个类时,一般会用到以下的方法


1.用于展示数据的方法 

   A.遵守 UITableViewDataSource 协议  

       指定分区数           

      - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView

       指定行数 必须

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

       指定内容 必须

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

  B.遵守 UITableViewDelegate 协议

        点击某行 响应的方法  

      - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath;


2.tableView的可编辑状态
       A. 使tableView进入可编辑模式     实现方法
    [self.tableView setEditing:!self.tableView.editing animated:YES];
    if (self.tableView.editing) {
        button.title=@"完成";
    }else{
        button.title=@"编辑";
    }
B.设置可编辑的区域

-(BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath{

    if (indexPath.row==0) {
        return NO;
    }
    return YES;
}

C.编辑状态的设置  删除 增加

-(UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath{
    
    
    if (indexPath.row==self.dataArray.count-1) {
        return UITableViewCellEditingStyleInsert;
    }
    return UITableViewCellEditingStyleDelete;


}

D.编辑状态模式下被点中执行

- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath {
    if (editingStyle == UITableViewCellEditingStyleDelete) {
        // Delete the row from the data source
        
        //1删除model层的数据
        [self.dataArray removeObjectAtIndex:indexPath.row];
        
        //删除tableview里地数据内容
        [tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];
    } else if (editingStyle == UITableViewCellEditingStyleInsert) {
        //1.添加到model层
        [self.dataArray addObject:@"asd"]; 
        //2.添加到tableview中
        NSIndexPath *ip=[NSIndexPath indexPathForRow:indexPath.row+1 inSection:0];
        [tableView insertRowsAtIndexPaths:@[ip] withRowAnimation:UITableViewRowAnimationLeft]; 
    }
}


3.系统提供了4种辅助视图

    由一个枚举型区分:

      UITableViewCellAccessoryType:

      DisclosureIndicator:一个“>”号,提示用户点击此Cell有更详细的信息。

      DetailDisclosureButton:  一个"i"按钮+">",提示用户点击此按钮而不是Cell会由更详细的信息。调用

 一个方法来展示详细信息 -(void)tableview:accessorButtonTappedForRowWithIndexPath:

      Checkmark:  一个"√",相当于打个标记

      DetailButton: 一个"i"按钮,提示用户,点击此按钮会调用方法(void)tableview:accessorButtonTappedForRowWithIndexPath:


A.UITableViewCellAccessoryCheckmark

状态的修改在点中cell时执行如下方法

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {  
    //checkmark用法
    UITableViewCell *cell=[tableView cellForRowAtIndexPath:indexPath];
    if (cell.accessoryType==UITableViewCellAccessoryCheckmark) {
        cell.accessoryType=UITableViewCellAccessoryNone;
        
    }else{
        cell.accessoryType=UITableViewCellAccessoryCheckmark;
    
    }
}


B.也可以给cell自定义辅助视图

if (indexPath.section==0&&indexPath.row==0) {
        cell.textLabel.text=@"蓝牙";
        UISwitch *blueSwitch=[[UISwitch alloc]init];
        cell.accessoryView=blueSwitch;
    }else if (indexPath.section==0&&indexPath.row==1){
        cell.textLabel.text=@"运营商";
        UIButton *button=[UIButton buttonWithType:UIButtonTypeSystem];
        button.frame=CGRectMake(0, 0, 44, 44);
        [button setTitle:@"选择" forState:UIControlStateNormal];
        [button addTarget:self action:nil  forControlEvents:UIControlEventTouchUpInside];
        cell.accessoryView=button;
    }






   
 
            
        

    

    }



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值