iOS UITableViewCell滑动删除

首先,我们初始化一个界面,以列表的形式展示

1
2
3
4
5
6
7
8
9
10
11
#pragma mark - 初始化UI
- ( void )initUI{
     self .view.backgroundColor = RGB(242, 242, 247);
     self .automaticallyAdjustsScrollViewInsets =  NO ;
     sideslipTableView = [[UITableView alloc] initWithFrame:CGRectMake(0, 60, kScreenWidth, kScreenHeight - 60) style:UITableViewStylePlain];
     sideslipTableView.backgroundColor = [UIColor clearColor];
     sideslipTableView.delegate =  self ;
     sideslipTableView.dataSource =  self ;
     sideslipTableView.separatorStyle = UITableViewCellSeparatorStyleNone;
     [ self .view addSubview:sideslipTableView];
}

然后,准备数据源

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@interface  ViewController ()<UITableViewDataSource,UITableViewDelegate>{
     UITableView *sideslipTableView;
     //可变数组,用于删除数据
     NSMutableArray  *dataArray;
     
}
 
@end
 
@implementation  ViewController
 
- ( void )viewDidLoad {
     [ super  viewDidLoad];
     
     [ self  initUI];
     dataArray = [ NSMutableArray  arrayWithArray: @[ @"1111" , @"2222" , @"3333" , @"4444" , @"5555" , @"6666" , @"7777" , @"8888" , @"9999" ]];
}

接下来我们要将数据显示出来

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#pragma mark - 行
- ( NSInteger )tableView:(UITableView *)tableView numberOfRowsInSection:( NSInteger )section{
     return  dataArray.count;
}
#pragma mark - 行高
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:( NSIndexPath  *)indexPath{
     return  46;
}
#pragma mark - cell内容
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:( NSIndexPath  *)indexPath{
     static  NSString  *indefier =  @"cell" ;
     sideslipTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:indefier];
     if  (!cell) {
         cell = [[sideslipTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:indefier];
     }
     cell.selectionStyle = UITableViewCellSelectionStyleNone;
     cell.lable.text = dataArray[indexPath.row];
     return  cell;
}

最后,实现UITableView的一些代理方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//先要设Cell可编辑
- ( BOOL )tableView:(UITableView *)tableView canEditRowAtIndexPath:( NSIndexPath  *)indexPath
{
     return  YES ;
}
//定义编辑样式
- (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:( NSIndexPath  *)indexPath
{
     return  UITableViewCellEditingStyleDelete;
}
//进入编辑模式,按下出现的编辑按钮后,进行删除操作
- ( void )tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:( NSIndexPath  *)indexPath
{
     if  (editingStyle == UITableViewCellEditingStyleDelete) {
         [dataArray removeObjectAtIndex:indexPath.row];
         // Delete the row from the data source.
         [sideslipTableView deleteRowsAtIndexPaths:[ NSArray  arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
     }
}
//修改编辑按钮文字
- ( NSString  *)tableView:(UITableView *)tableView titleForDeleteConfirmationButtonForRowAtIndexPath:( NSIndexPath  *)indexPath
{
     return  @"删除" ;
}

这样就可以实现UITableViewCell滑动删除的效果啦。
效果图:


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值