一、前言
这次分享并记录一下tableView的多选删除,并额外记录一下单选删除及tableView的设置小技巧。
二、想要实现的效果图如下:
1、先上原图
2、然后编辑图如下:
3、编辑步骤:
点击右上角按钮编辑,界面呈现编辑状态底部删除按钮弹出
选择删除cell项,点击右下角删除可删除
点击右上角,退出编辑状态,底部删除按钮退出界面
三、多选删除核心代码
1、设置允许tableView编辑状态下允许多选
_mainTableView.allowsMultipleSelectionDuringEditing = YES;
2、将cell设置为可选择的风格(下面代码是在自定义Cell内部)
self.selectionStyle = UITableViewCellSelectionStyleDefault;
说明:因为自认为系统的选中状态很难看,所以在cell的基类里已经把 selectionStyle 设置为None,但是想要多选必须将其打开,大家切记。
3、不喜欢系统的选中状态,可更改选中状态的背景(下面也是在自定义cell内部)
UIView *view = [[UIView alloc] init]; view.backgroundColor = UIColorFromRGB(0xF6F6F6); self.selectedBackgroundView = view;
4、右上角点击事件
[self.viewModel.rightViewModel.clickSubject subscribeNext:^(id x) { @strongify(self); if (self.mainTableView.editing) { self.viewModel.rightViewModel.title = @"编辑"; [UIView animateWithDuration:0.5 animations:^{ [self.mainTableView mas_remakeConstraints:^(MASConstraintMaker *make) { @strongify(self); make.edges.equalTo(self); }]; }]; } else { self.viewModel.rightViewModel.title = @"确定"; [UIView animateWithDuration:0.5 animations:^{ [self.mainTableView mas_remakeConstraints:^(MASConstraintMaker *make) { @strongify(self); make.left.right.top.equalTo(self); make.bottom.equalTo(-50); }]; }]; } [self.mainTableView setEditing:!self.mainTableView.editing animated:YES]; }];
5、右下角删除事件
[[[self.deleteBtn rac_signalForControlEvents:UIControlEventTouchUpInside] takeUntil:self.rac_willDeallocSignal] subscribeNext:^(id x) { @strongify(self); NSMutableArray *deleteArray = [NSMutableArray array]; for (NSIndexPath *indexPath in self.mainTableView.indexPathsForSelectedRows) { [deleteArray addObject:self.viewModel.dataArray[indexPath.row]]; } NSMutableArray *currentArray = self.viewModel.dataArray; [currentArray removeObjectsInArray:deleteArray]; self.viewModel.dataArray = currentArray; [self.mainTableView deleteRowsAtIndexPaths:self.mainTableView.indexPathsForSelectedRows withRowAnimation:UITableViewRowAnimationLeft];//删除对应数据的cell dispatch_time_t delayTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)); dispatch_after(delayTime, dispatch_get_main_queue(), ^{ @strongify(self); [self.mainTableView reloadData]; }); }];
四、单个删除(分为系统左滑,和点击cell上删除按钮两种)
1、系统左滑
#pragma mark - delete - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath { return UITableViewCellEditingStyleDelete; } - (NSString *)tableView:(UITableView *)tableView titleForDeleteConfirmationButtonForRowAtIndexPath:(NSIndexPath *)indexPath { return @"删除此经验"; } - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath { [self.viewModel.deleteCommand execute:indexPath]; }
说明:删除操作数据及UI刷新和多选是一致的,就不上代码了,这里只需注意左滑需要遵循的系统代理就行。
2、点击Cell删除
与系统左滑删除的不同仅仅是手动触发删除事件而已。
[[[self.deleteBtn rac_signalForControlEvents:UIControlEventTouchUpInside] takeUntil:self.rac_prepareForReuseSignal] subscribeNext:^(id x) { [viewModel.deleteCommand execute:nil]; }];
单个删除的操作数据和UI刷新也上下代码吧!(虽然有些重复o(╯□╰)o)
[[self.viewModel.deleteSubject takeUntil:self.rac_willDeallocSignal] subscribeNext:^(NSIndexPath *indexPath) { @strongify(self); if (self.viewModel.dataArray.count > indexPath.row) { [self.viewModel.dataArray removeObjectAtIndex:indexPath.row]; //删除数组里的数据 [self.mainTableView deleteRowsAtIndexPaths:[NSMutableArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationLeft];//删除对应数据的cell dispatch_time_t delayTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)); dispatch_after(delayTime, dispatch_get_main_queue(), ^{ @strongify(self); [self.mainTableView reloadData]; }); } }];
五、tableView的一些Tips(不常用的,或没注意的)
1、设置tableView可不可以选中(防止cell重复点击也可以利用这条特性)
self.tableView.allowsSelection = NO;
2、允许tableview多选
self.tableView.allowsMultipleSelection = YES;
3、编辑模式下是否可以选中
self.tableView.allowsSelectionDuringEditing = NO;
4、编辑模式下是否可以多选
self.tableView.allowsMultipleSelectionDuringEditing = YES;
5、获取被选中的所有行
[self.tableView indexPathsForSelectedRows]
6、获取当前可见的行
[self.tableView indexPathsForVisibleRows];
7、 改变UITableViewCell选中时背景色
cell.selectedBackgroundView.backgroundColor
8、自定义UITableViewCell选中时背景
cell.selectedBackgroundView
9、自定义UITableViewCell选中时系统label字体颜色
cell.textLabel.highlightedTextColor
10、设置tableViewCell间的分割线的颜色
[theTableView setSeparatorColor:[UIColor xxxx ]];
11、pop返回table时,cell自动取消选中状态(在viewWillAppear中添加如下代码)
[self.tableView deselectRowAtIndexPath:[self.tableView indexPathForSelectedRow] animated:YES];
12、点击后,过段时间cell自动取消选中
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { //消除cell选择痕迹 [self performSelector:@selector(deselect) withObject:nil afterDelay:0.5f]; } - (void)deselect { [self.tableview deselectRowAtIndexPath:[self.tableview indexPathForSelectedRow] animated:YES]; }
以上所述是小编给大家介绍的AniOS 多选删除功能附tableViewTips及单选删除,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
主要内容:Nimbus 的 现有代码,Nimbus 的 新代码,Aqua 的 现有代码,Aqua 的 新代码JDK 10 版本从 Java 库中删除了几个不推荐使用的 API、特性和选项。以下是相关详情。 删除了不支持的 LookAndFeels - 使用 Nimbus 或 Aqua LookAndFeels 的应用程序必须迁移到新语法。 Nimbus 的 现有代码 Nimbus 的 新代码 Aqua 的 现有代码 Aqua 的 新代码 删除了 Runtime.getLocalizedInput
本文向大家介绍JS实现复选框的全选和批量删除功能,包括了JS实现复选框的全选和批量删除功能的使用技巧和注意事项,需要的朋友参考一下 如图示: 功能描述:在勾选了全选时,所有的商品都会勾选,在取消全选时,取消所有物品的勾选。如果点击批量删除,删除所勾选的商品。 如代码所示,全选/全不选的复选框添加onclick事件。每当点击了这个复选框时,触发ckAll事件。在ckAll()方法中,我们首先获得al
问题内容: 我很难解决多个复选框删除问题。有人可以指导我解决问题吗?此处应该发生的情况是,用户可以在框上打勾,然后单击“删除”按钮以删除被打勾的框。不幸的是,我的代码似乎无效。你能为我指出正确的方向吗? 问题答案: 此HTML: 应该: 该查询应为:
本文向大家介绍java实现选中删除功能的实例代码,包括了java实现选中删除功能的实例代码的使用技巧和注意事项,需要的朋友参考一下 分析: 通过form表单传递数据,删除数据根据id编号删除。 前台 Js 后台 Servlet Service Dao 总结 以上所述是小编给大家介绍的java实现选中删除功能的实例代码,希望对大家有所帮助!
我有一个JTable,它显示保存在ArrayList集合中的customer对象列表。从这个JTable中,我希望能够突出显示一个特定的客户,然后单击一个“delete customer”按钮,该按钮从选定的表行中提取ID列值,并用它用迭代器在ArrayList中搜索,找到匹配的客户,并将其从集合中删除。我在swing组件和eventlisteners方面的专业知识还有很多需要改进的地方,到目前为
本文向大家介绍vue实现单选和多选功能,包括了vue实现单选和多选功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了vue实现单选和多选功能的具体代码,供大家参考,具体内容如下复制代码 vue实现多选功能 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。