iOS 中使用tableView实现右滑显示选择功能
1、在ios8以前,我们实现tableview中滑动显示删除,置顶,更多等等的按钮时,都需要自己去实现,在ios8中系统已经写好了,只要一个代理方法和一个类就行了
2、ios8的协议对了一个方法,返回值是数组的tableview:editactionforrowatindexpath:方法,我们可以在方法内部写好几个按钮,然后放到数组中返回,那些按钮的类就是uitableviewrowaction
3、在uitableviewrowaction类。我们可以设置按钮的样式,显示文字、背景色和按钮事件(在block内实现)
4、在代理方法中,我们可以常见多个按钮放到数组中返回,最先放入数组的按钮显示在最右边,最后放入的显示在最左边
5、如果自己设定一个或多个按钮,系统自带的删除按钮就消失了
设置tableview可以编辑
- (bool)tableview: (uitableview *)tableview shouldindentwhileeditingrowatindexpath:(nsindexpath *)indexpath { return yes; }
uitableviewrowaction的使用方法:
+ (instancetype)rowactionwithstyle:(uitableviewrowactionstyle)style title:(nullable nsstring *)title handler:(void (^)(uitableviewrowaction *action, nsindexpath *indexpath))handler;
重写uitableviewdelegate的
- (nullable nsarray<uitableviewrowaction *> *)tableview:(uitableview *)tableview editactionsforrowatindexpath:(nsindexpath *)indexpath
方法。
- (nsarray *)tableview:(uitableview *)tableview editactionsforrowatindexpath:(nsindexpath *)indexpath { if(indexpath.row==0){ // 添加一个删除按钮 deleterowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstyledestructive title:@"删除" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了删除"); }]; } else if (indexpath.row==1){ // 添加一个删除按钮 deleterowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstyledestructive title:@"删除" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了删除"); }]; // 添加一个修改按钮 morerowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"修改" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了修改"); }]; morerowaction.backgroundeffect = [uiblureffect effectwithstyle:uiblureffectstyledark]; } else if (indexpath.row==2){ // 添加一个删除按钮 deleterowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstyledestructive title:@"删除" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了删除"); }]; // 添加一个修改按钮 morerowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"修改" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了修改"); }]; morerowaction.backgroundeffect = [uiblureffect effectwithstyle:uiblureffectstyledark]; // 添加一个发送按钮 sanrowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"发送" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了发送"); }]; sanrowaction.backgroundcolor=[uicolor orangecolor]; } else{ // 添加一个删除按钮 deleterowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstyledestructive title:@"删除" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了删除"); }]; // 添加一个修改按钮 morerowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"修改" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了修改"); }]; morerowaction.backgroundeffect = [uiblureffect effectwithstyle:uiblureffectstyledark]; // 添加一个发送按钮 sanrowaction = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"发送" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了发送"); }]; sanrowaction.backgroundcolor=[uicolor orangecolor]; // 添加一个发送按钮 ok = [uitableviewrowaction rowactionwithstyle:uitableviewrowactionstylenormal title:@"ok键" handler:^(uitableviewrowaction *action, nsindexpath *indexpath) { nslog(@"点击了ok"); }]; ok.backgroundcolor=[uicolor purplecolor]; } // 将设置好的按钮放到数组中返回 if (indexpath.row==0) { return @[deleterowaction]; }else if (indexpath.row==1){ return @[deleterowaction,morerowaction]; }else if(indexpath.row==2){ return @[deleterowaction,morerowaction,sanrowaction]; }else if(indexpath.row==3){ return @[deleterowaction,morerowaction,sanrowaction,ok]; } return nil; }
以上所述是小编给大家介绍的ios 中使用tableview实现右滑显示选择功能的相关资料,希望对大家有所帮助。