UITableViewCell 多选和全选(checkBoxCell)
思路1
一、单选
1、创建一个currentIndexPath为了记录当前选择的indexPath。
2、 如果是记录上一次选中的内容,可以通过模型中的是否选中来初始化indexPathForRow。
3、首先判断创建的indexPath是否等于当前点击的indexPath。
4、如果不等于数组中的模型全部置为NO。
5、再将当前点击的indexPath传给创建的currentIndexPath,并刷新当前表格(传创建的currentIndexPath)。
6、通过点击的indexPath取出当前模型并取反,再通过点击的indexPath刷新表格
代码如下:
1、_indexPath = [NSIndexPath indexPathForRow:[group.brand indexOfObject:viewModel] inSection:[_dataArray indexOfObject:group]];//取出选中的行及列,viewModel表示是选中的模型,如果进入页面不需要设置上一次选中的内容可以不写这一步。
2、NSIndexPath *selectIndexPath = _indexPath;
if (selectIndexPath && selectIndexPath != indexPath) {//判断创建的indexPath是否不等于点击的indexPath
for (GMeSaleAreaGroupViewModel *GviewModel in _dataArray) {//如果不等于置为NO
for (GMeSaleAreaViewModel*viewModel in GviewModel.brand) {
viewModel.isSelect = NO;
}
}
//刷新没有选中的表格
[tableView reloadRowsAtIndexPaths:@[_indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
}
_indexPath = indexPath; //点击的indexPath传给上一个点击的indexPath
GMeSaleAreaViewModel *viewModel = [GroupViewModel.brand objectAtIndex:indexPath.row]; //取出当前点击的indexPath
viewModel.isSelect = !viewModel.isSelect;//取反
[tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];//刷新当前点击的表格
二、全选
1.创建可变数组,存储所有未选中状态(NO)的布尔值按钮,点击时改变其状态,并传入按钮的状态。
三、多选
1.创建Cell时,从数组中取出相应的值,传给cell,如果为YES,否则为NO.
2.点击cell时,从数组中取出相应的值,取反,然后刷新该行。
四、代码先行
#import "ViewController.h"
#import "CheckBoxCell.h"
@interface ViewController ()<UITableViewDelegate,UITableViewDataSource>{ UITableView *_tableView;
}
@property (nonatomic, strong)NSMutableArray *dataArray;
@end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[self loadUI];
[self loadDataWithSelected:NO];
}
- (void)loadUI{ _tableView = [[UITableView alloc] initWithFrame:CGRectMake(, ,self.view.bounds.size.width,self.view.bounds.size.height - ) style:UITableViewStylePlain];
_tableView.delegate = self;
_tableView.dataSource = self;
[self.view addSubview:_tableView]; UIButton *customBtn = [UIButton buttonWithType:UIButtonTypeCustom];
[customBtn setFrame:CGRectMake(, , , )];
[customBtn setBackgroundColor:[UIColor lightGrayColor]];
[customBtn setTitle:@"多选" forState:UIControlStateNormal];
[customBtn setTitleColor:[UIColor redColor] forState:UIControlStateHighlighted];
[customBtn setTitle:@"全选" forState:UIControlStateSelected];
[customBtn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:customBtn];
}
- (void)loadDataWithSelected:(BOOL)isSelected{ NSMutableArray *arr = [NSMutableArray array];
for (NSInteger i = ; i< ; i++) {
[arr addObject:@(isSelected)];
}
self.dataArray = arr;
[_tableView reloadData];
}
- (void)btnClick:(UIButton *)sender{ [self loadDataWithSelected:sender.selected];
sender.selected = !sender.selected; }
#pragma mark --- tableview
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
return self.dataArray.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ static NSString *ID = @"checkBoxCell";
CheckBoxCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
if (cell == nil) {
cell = [[CheckBoxCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
}
if (self.dataArray.count > indexPath.row) {
NSNumber *selected = [self.dataArray objectAtIndex:indexPath.row];
[cell setChecked:selected.boolValue];
}
return cell;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{ [tableView deselectRowAtIndexPath:indexPath animated:YES]; if (self.dataArray.count > indexPath.row) {
NSNumber *selected = self.dataArray [indexPath.row];
self.dataArray[indexPath.row] = @(!selected.boolValue);
[tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];
} }
cell代码同下;
思路2
原文地址: http://www.cnblogs.com/hxwj/p/4532172.html
思路分析
前期准备:1.创建两个数组:一个数据数组array,一个状态数组checkArray,(初始化时每一个值为NO).
2.多选,初始化时存入所有NO值给checkArray,点击cell时取出每一值取反,全选则是根据按钮状态,如果是选中全部为YES,否则全部为NO。
一.全选
1.点击时反选按钮状态,取出所有indexPath未选中状态给新的数组,然后遍历取出相应的indexpath,cell和row;
2.取出每一个值,如果是选中,设置为YES,否则设置为NO.
二.多选(点击cell时,取出相应的row和cell,根据row从checkArray取出一项,并设置cell状态)
1.当cell点击时,根据点击cell的row从checkArray取出相应的项,改变其值,如果是YES,设置为YES,否则设置为NO。
三.代码先行
cell
#import "CheckBoxCell.h"
@interface CheckBoxCell(){ BOOL _isSelect;
UIImageView *_chectImageView; }
@end
@implementation CheckBoxCell - (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier{
if (self == [super initWithStyle:style reuseIdentifier:reuseIdentifier]) { _chectImageView = [[UIImageView alloc] init];
_chectImageView.image = [UIImage imageNamed:@"normal"];
[self.contentView addSubview:_chectImageView];
}
return self;
} - (void)layoutSubviews{ [super layoutSubviews];
[_chectImageView setFrame:CGRectMake(, ,, )];
}
- (void)setchecked:(BOOL)checked{ _isSelect = checked;
if(_isSelect){ _chectImageView.image = [UIImage imageNamed:@"select"];
}else{
_chectImageView.image = [UIImage imageNamed:@"normal"];
}
VIewControll
#import "ChectBoxViewController.h"
#import "CheckBoxCell.h"
@interface ChectBoxViewController ()<UITableViewDelegate,UITableViewDataSource>{ UITableView *_tableView;
}
@property (nonatomic, strong)NSArray *array;
@property (nonatomic, strong)NSMutableArray *chectArray;
@end @implementation ChectBoxViewController - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
[self loadUI];
[self loadData];
}
#pragma mark --- viewDidLoad
- (void)loadUI{ _tableView = [[UITableView alloc] initWithFrame:CGRectMake(,, self.view.bounds.size.width, self.view.bounds.size.height) style:UITableViewStylePlain];
_tableView.delegate = self;
_tableView.dataSource = self;
[_tableView setBackgroundColor:[UIColor lightGrayColor]];
[self.view addSubview:_tableView]; UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
[btn setTitle:@"多选" forState:UIControlStateNormal];
[btn setTitle:@"全选" forState:UIControlStateSelected];
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
[btn setFrame:CGRectMake(, , , )];
[btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[self.view addSubview:btn];
}
- (void)loadData{ _chectArray = [NSMutableArray array];
for (NSInteger i = ; i < self.array.count; i++) {
NSMutableDictionary *dic = [NSMutableDictionary dictionary];
[dic setValue:@"NO" forKey:@"checked"];
[_chectArray addObject:dic];
}
}
#pragma mark --- tableView
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
return self.array.count;
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ static NSString *ID = @"checkboxCell";
CheckBoxCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
if (cell == nil) {
cell = [[CheckBoxCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
}
return cell;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{ [tableView deselectRowAtIndexPath:indexPath animated:YES]; CheckBoxCell*cell = (CheckBoxCell *)[tableView cellForRowAtIndexPath:indexPath];
NSInteger row = indexPath.row;
[self cellChecked:cell row:row isSelected:YES];
} #pragma mark --- response methods
/**
* 点击,和加载cell的时候进行判断,从而改变cell的选中状态
*
* @param cell 自定义cell
* @param row tableView的下标
* @param selected 是否是点击
*/
- (void)cellChecked:(CheckBoxCell *)cell row:(NSInteger)row isSelected:(BOOL)selected{ NSMutableDictionary *dic = [_chectArray objectAtIndex:row];
if ([[dic objectForKey:@"checked"] isEqualToString:@"NO"]) {
if (selected) {
[dic setObject:@"YES" forKey:@"checked"];
[cell setchecked:YES];
}
}else{ if (selected) {
[dic setObject:@"NO" forKey:@"checked"];
[cell setchecked:NO];
}
}
}
- (void)btnClick:(UIButton *)sender{//全选 sender.selected = !sender.selected; NSArray *arrayOfIndexPath = [NSArray arrayWithArray:[_tableView indexPathsForVisibleRows]];
for (NSInteger i = ; i < arrayOfIndexPath.count; i++) {
NSIndexPath *indexPath = [arrayOfIndexPath objectAtIndex: i];
CheckBoxCell *cell = (CheckBoxCell *)[_tableView cellForRowAtIndexPath:indexPath];
NSUInteger row = [indexPath row];
NSMutableDictionary *dic = [_chectArray objectAtIndex:row];
if (sender.selected) {
[dic setObject:@"YES" forKey:@"checked"];
[cell setchecked:YES];
}else{
[dic setObject:@"NO" forKey:@"checked"];
[cell setchecked:NO];
}
}
}
- (NSArray *)array{
if (_array == nil) {
_array = [[NSMutableArray alloc] initWithObjects:@"",@"",@"",@"",@"", nil];
}
return _array;
}
UITableViewCell 多选和全选(checkBoxCell)的更多相关文章
- IOS开发学习笔记029-反选、全选、删除按钮的实现
还是在上一个程序的基础上进行修改 1.反选按钮 2.全选按钮 3.删除按钮 4.其他代码优化 1.反选按钮 反选的过程就是将_deleteShops数组中得数据清空,然后将Shops中数组添加到_de ...
- js 复选框 全选都选 如果某一个子复选框没选中 则全选按钮不选中
<!DOCTYPE HTML> <html> <head> <meta charset=UTF-8> <title>js 复选框 全选都选 ...
- CheckBox复选框全选以及获取值
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- JavaScript小例子:复选框全选
JavaScript小例子:复选框全选 这只是一个小例子,很简单,但是这个功能还是很常用的: 实现后效果如图: JavaScript代码: <script type="text/jav ...
- Jquery表格变色 复选框全选,反选
/*jquery静态表格变色*/ $(".tr2").mouseover(function(){ $(this).css("background"," ...
- 复选框全选、全不选和反选的效果实现VIEW:1592
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- Jquery CheckBox复选框 全选/取消全选 最佳实现方式 参考案例
<input id="chkAll" type="checkbox" />全选/取消全选</div> <asp:Repeater ...
- html+css+js实现复选框全选与反选
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- checkbox复选框全选批量删除
多选框全选实现批量删除 html代码 <body> <form action="" method="post" name="Form ...
- 关于在repeater中的checkbox实行多选和全选
今天项目中用到这一块,是一个b2b商城,业务是别人给客户留言后,客户从会员中心的留言管理中查看,用checkbox实行多选和全选后进行批量审核 首先在checkbox后加个hidden,作用见代码: ...
随机推荐
- IDA来Patch android的so文件
在上文中,我们通过分析定位到sub_130C()这个函数有很大可能性是用来做反调试检测的,并且作者开了一个新的线程,并且用了一个while来不断执行sub_130C()这个函数,所以说我们每次手动的修 ...
- static和extern对函数的作用
- 【代码笔记】iOS-多张图片合成一张
代码: RootViewController.m #import "RootViewController.h" @interface RootViewController () @ ...
- GCD的深入理解
GCD 深入理解(一) 本文由@nixzhu翻译至raywenderlich的<grand-central-dispatch-in-depth-part-1> 虽然 GCD 已经出现过一段 ...
- Android源码分析之SharedPreferences
在Android的日常开发中,相信大家都用过SharedPreferences来保存用户的某些settings值.Shared Preferences 以键值对的形式存储私有的原生类型数据,这里的私有 ...
- 【转】面向对象设计的SOLID原则
S.O.L.I.D是面向对象设计和编程(OOD&OOP)中几个重要编码原则(Programming Priciple)的首字母缩写. SRP The Single Responsibility ...
- Jexus-5.6.3使用详解、Jexus Web Server配置
一.Jexus Web Server配置 在 jexus 的工作文件夹中(一般是“/usr/jexus”)有一个基本的配置文件,文件名是“jws.conf”. jws.conf 中至少有 Site ...
- vs2015密钥 企业版 专业版 (vs.net)
专业版:HMGNV-WCYXV-X7G9W-YCX63-B98R2企业版:HM6NR-QXX7C-DFW2Y-8B82K-WTYJV
- (视频) 开源,免费和跨平台 - MVP ComCamp 2015 KEYNOTE
2015年1月31日,作为KEYNOTE演讲嘉宾,我和来自全国各地的开发人员分享了作为一名MVP的一些体会. Keynote – Open Source, Free Tools and Cross P ...
- Eclipse--Web项目中 .classpath、mymetadata、project文件的功用
Web项目中 .classpath..mymetadata..project文件的作用 创建Web Project时,会自动生成这个三个文件. 一..mymetadata文件 1.部署项目用的,把项目 ...