一般勾选多选问题时,都是默认未选中,重新选择勾选上传选中数据给后台,但是遇到下面这种情况,勾选项默认下发时要回显已经添加的原料元素!
整理解决思路:我这里是用 MVC 设计模式做处理
- Model 里添加一个是否选中的布尔值selected
- View 里赋值时需要判断是否选中selected来相对应换是否勾选图片
- 当前Controller里创建盛放所有元素的数组 及 选中元素的数组 及 展现数据
- 当前Controller里选中当前行操作
- 点击确认上传后台操作逻辑
如果多选思路和这里差不多的话, 可以直接看第三点即可:下发列表前回显问题.
一.Model 里添加一个是否选中的布尔值selected
我这边因为还需要之前回显是否勾选,这里面还需要后台添加一个字段isCheck.(如果一般情况木勾选项下发时时回显则不需要添加该字段)
// 原料id
@property (nonatomic, copy) NSString *materialId;
// 原料名称
@property (nonatomic, copy) NSString *materialName;
// 是否勾选 1为勾选
@property (nonatomic, assign) NSInteger isCheck;
// 是否选中
@property (nonatomic, assign, getter=isSelected) BOOL selected;
二. View 里赋值时需要判断是否选中selected来相对应换是否勾选图片
// model赋值
- (void)setModel:(XHHMaterialModel *)model {
_model = model;
self.stock.text = model.materialName;
if (model.selected == YES) {
self.selectImg.image = [UIImage imageNamed:@"xz"];
} else{
self.selectImg.image = [UIImage imageNamed:@"wx"];
}
}
三. 当前Controller里创建盛放所有元素的数组 及 选中元素的数组 及 展现数据
// 原料数组
@property (nonatomic, strong) NSMutableArray *list;
// 多选数组
@property (nonatomic, strong) NSMutableArray *selectedEditList;
- (NSMutableArray *)list {
if (!_list) {
_list = [NSMutableArray array];
}
return _list;
}
- (NSMutableArray *)selectedEditList {
if (!_selectedEditList) {
_selectedEditList = [NSMutableArray array];
}
return _selectedEditList;
}
网络获取列表数据, 根据后台定义isCheck字段判断是否勾选,这里我们后台告知当是1的情况就勾选上,否则未勾选.(如果如果一般情况木勾选项下发时回显则不需要添加该逻辑:插入选中数据到多选数组)
- (void)loadListNetData {
// 移除所有数据
[weakSelf.list removeAllObjects];
NSArray *currentPageArray = [XHHMaterialModel loadMaterialInfoFromJson:json[@"data"]];
[weakSelf.list addObjectsFromArray:currentPageArray];
// 遍历显示模型中原本已勾选值
for (XHHMaterialModel *model in currentPageArray) {
if (model.isCheck == 1) { // 1为勾选 将该数据插入到多选数组
model.selected = YES;
[self.selectedEditList addObject:model];
} else {
model.selected = NO;
[self.selectedEditList removeObject:model];
}
}
}
四. 当前Controller里选中当前行操作
// 选中当前行
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
XHHMaterialModel *model = self.list[indexPath.row];
// 编辑状态 点击选中
model.selected = !model.selected;
[self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];
if (model.selected) {
[self.selectedEditList addObject:model];
} else {
[self.selectedEditList removeObject:model];
}
// 视图退出编辑状态(收起键盘)
[self.view endEditing:YES];
}
五. 点击确认上传后台操作逻辑
这里面我们和后台定义是传ID 串
/**
* 确认
*/
- (void)bottomBtnPress {
// 发送增加原料确认
[self sendMaterialIdStrDataArray:self.selectedEditList];
}
/**
* 发送增加原料确认
*/
- (void)sendMaterialIdStrDataArray:(NSArray *)array {
NSArray *idArray = [array valueForKeyPath:@"materialId"];
NSString *materialIdStr = [idArray componentsJoinedByString:@","];
self.materialIdStr = materialIdStr;
if (self.materialIdStr.length == 0) { // 未勾选时滤掉不发请求
[MBProgressHUD showError:@"请先选择原料"];
return;
} else if (self.selectedEditList.count > 5) { // 多选限制
[MBProgressHUD showError:@"最多选择5个原料"];
return;
}
// 发送请求
NSMutableDictionary *params = [NSMutableDictionary dictionary];
params[@"userId"] = [NSString stringWithString:[XHHAccountTool account].userid];
params[@"materialIdStr"] = self.materialIdStr;
[XHHHttpTool post:XHH_insetFormulaAdd_url params:params success:^(id json) {
XHHLog(@"增加原料 请求成功-%@", json);
if ([json[@"success"] isEqual:@(YES)]) {
[MBProgressHUD showSuccess:@"增加原料成功"];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.7 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ // 延时0.7s后返回
[self.navigationController popViewControllerAnimated:YES];
});
} else {
[MBProgressHUD showError:[NSString stringWithFormat:@"%@", json[@"errorMessage"]]];
}
} failure:^(NSError *error) {
[MBProgressHUD showError:@"暂无网络,稍后再试"];
XHHLog(@"增加原料 请求失败-%@", error);
}];
}
PS:
刚才一个简友简信我:"亲 请问能限制勾选的个数嘛?该如何实现!"
我这里就补充一下这个小思路, 假设多选限制5个, 判断一下多选数组的个数再上传后台时限制一下就可以了啊
if (self.selectedEditList.count > 5) { // 多选限制
[MBProgressHUD showError:@"最多选择5个原料"];
return;
}
OK, 有兴趣的话可以测试一下🙂