iOS-多选勾选(下发列表前回显勾选问题)

一般勾选多选问题时,都是默认未选中,重新选择勾选上传选中数据给后台,但是遇到下面这种情况,勾选项默认下发时要回显已经添加的原料元素!


整理解决思路:我这里是用 MVC 设计模式做处理

  1. Model 里添加一个是否选中的布尔值selected
  2. View 里赋值时需要判断是否选中selected来相对应换是否勾选图片
  3. 当前Controller里创建盛放所有元素的数组 及 选中元素的数组 及 展现数据
  4. 当前Controller里选中当前行操作
  5. 点击确认上传后台操作逻辑

如果多选思路和这里差不多的话, 可以直接看第三点即可:下发列表前回显问题.

一.Model 里添加一个是否选中的布尔值selected

我这边因为还需要之前回显是否勾选,这里面还需要后台添加一个字段isCheck.(如果一般情况木勾选项下发时时回显则不需要添加该字段)

// 原料id
@property (nonatomic, copy) NSString *id;

// 原料名称
@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:@"id"];
    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, 有兴趣的话可以测试一下🙂

推荐阅读更多精彩内容