好久没更新博客了,今天写了一个自定义的多选列表,可以跟爱学习的各位进行分享,首先我们先来看一下效果图:

一般大家都是用UITableView自己的编辑模式来实现CheckBox的,这里我们用自定义Cell和两张图片来实现,一张是未选中,一张是选中的图片

好了,我们首先来看一下代码:首先在Cell中定义了三个控件,两个UILabel和一个UIImageView

  1. #import <UIKit/UIKit.h>
  2. @interface MultiChoceCell : UITableViewCell
  3. @property (strong, nonatomic) IBOutlet UILabel *nameLabel;
  4. @property (strong, nonatomic) IBOutlet UILabel *departLable;
  5. @property (strong, nonatomic) IBOutlet UIImageView *checkBox;
  6. @end

好了,这个相信各位学过UITableViewCell的同学都应该知道,接下来,我们就来写最主要的ViewController了

在头文件.h文件里,我们首先定义了一个协议专门用来做回调的,还定义了一个选项数组和选中的数组,还有一个UITableView,我个人喜欢在ViewController里套上UITableView,因为可以改变TableView的大小。

  1. #import <UIKit/UIKit.h>
  2. @class MultiChoceViewController;
  3. @protocol MultiChoceDelegate <NSObject>
  4. @required
  5. -(void)MultiChoceSelectArray:(NSArray *)array ViewController:(MultiChoceViewController *)controller;
  6. @end
  7. @interface MultiChoceViewController : UIViewController<UITableViewDataSource, UITableViewDelegate>
  8. @property(nonatomic, strong)NSArray *itemArray;
  9. @property(nonatomic, strong)NSMutableArray *selectArray;
  10. @property (strong, nonatomic) IBOutlet UITableView *mTableView;
  11. @property (nonatomic, strong) id<MultiChoceDelegate> delegate;
  12. - (IBAction)backAction:(id)sender;
  13. - (IBAction)okAction:(id)sender;
  14. @end

接下来,我们看一下实现方式,在ViewDidLoad中将UITableView的颜色去掉,然后就是定义UITableViewDataSource和UITableViewDelegate了,看一下代码吧:

  1. #import "MultiChoceViewController.h"
  2. #import "MultiChoceCell.h"
  3. @interface MultiChoceViewController ()
  4. @end
  5. @implementation MultiChoceViewController
  6. - (void)viewDidLoad
  7. {
  8. [super viewDidLoad];
  9. [_mTableView setBackgroundColor:[UIColor clearColor]];
  10. // Do any additional setup after loading the view from its nib.
  11. }
  12. - (void)didReceiveMemoryWarning
  13. {
  14. [super didReceiveMemoryWarning];
  15. // Dispose of any resources that can be recreated.
  16. }
  17. #pragma mark UITableViewDataSource
  18. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
  19. return [_itemArray count];
  20. }
  21. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
  22. static NSString *identifier = @"itemCell";
  23. MultiChoceCell *cell = [tableView dequeueReusableCellWithIdentifier:identifier];
  24. if (cell == nil) {
  25. NSArray *array = [[NSBundle mainBundle] loadNibNamed:@"MultiChoceCell" owner:self options:nil];
  26. cell = [array objectAtIndex:0];
  27. }
  28. NSDictionary *dict = [_itemArray objectAtIndex:indexPath.row];
  29. cell.nameLabel.text = [dict objectForKey:@"UserName"];
  30. cell.departLable.text = [dict objectForKey:@"DepartMent"];
  31. if ([_selectArray containsObject:dict]) {
  32. cell.checkBox.image = [UIImage imageNamed:@"checked.png"];
  33. }
  34. return cell;
  35. }
  36. - (IBAction)backAction:(id)sender {
  37. [self.navigationController popViewControllerAnimated:YES];
  38. }
  39. - (IBAction)okAction:(id)sender {
  40. [_delegate MultiChoceSelectArray:_selectArray ViewController:self];
  41. }
  42. #pragma mark UITableViewDelegate
  43. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
  44. NSDictionary *selectDict = [_itemArray objectAtIndex:indexPath.row];
  1. //判断数据是否在选择列表中
  2. if ([_selectArray containsObject:selectDict]) {
  3. [_selectArray removeObject:selectDict];
  4. }else{
  5. [_selectArray addObject:selectDict];
  6. }
  7. [_mTableView reloadData];
  8. }
  9. @end

这里没什么特别的,只是在didSelectRowAtIndexPath中写了一句判断语句

在调用的页面,我们把itemArray和selectArray传入

  1. MultiChoceViewController *controlller = [[MultiChoceViewController alloc] initWithNibName:@"MultiChoceViewController" bundle:nil];
  2. controlller.delegate = self;
  3. controlller.itemArray = userArray;
  4. controlller.selectArray = selectArray;
  5. [self.navigationController pushViewController:controlller animated:YES];

并实现多选方法中中协议来关掉当前页面,并将选中的数据传出

  1. #pragma mark MultiChoceDelegate
  2. -(void)MultiChoceSelectArray:(NSMutableArray *)array ViewController:(MultiChoceViewController *)controller{
  3. selectArray = array;
  4. [self.navigationController popViewControllerAnimated:YES];
  5. }

这里有很重要的一点就是委托方法的应用,如果前面一个页面需要后面页面的数据,就要想到用委托来实现回调,其实只要掌握了委托一些页面间的传值也就不难了,这篇文章只是给大家做个介绍,但如何做出自己想要的效果还是需要多多练习和学习的。谢谢

iPhone实现自定义多选列表的更多相关文章

  1. WPF自定义控件与样式(8)-ComboBox与自定义多选控件MultComboBox

    一.前言 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接. 本文主要内容: 下拉选 ...

  2. c# 自定义多选下拉列表2

    以下为工作中遇到的,备注一下 先需要几个辅助类 #region GripBounds using System.Drawing; internal struct GripBounds { ; ; pu ...

  3. 【转】WPF自定义控件与样式(8)-ComboBox与自定义多选控件MultComboBox

    一.前言 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等. 本文主要内容: 下拉选择控件ComboBox的自定义样式及扩展: 自定义多选控件Mul ...

  4. WPF 自定义ComboBox样式,自定义多选控件

    原文:WPF 自定义ComboBox样式,自定义多选控件 一.ComboBox基本样式 ComboBox有两种状态,可编辑和不可编辑状态.通过设置IsEditable属性可以切换控件状态. 先看基本样 ...

  5. MVC应用程序与多选列表(checkbox list)

    原文:MVC应用程序与多选列表(checkbox list) 程序中,经常会使用checkbox lsit来呈现数.能让用户有多选项目.此博文Insus.NET练习的checkbox list相关各个 ...

  6. multiselect2side:jQuery多选列表框插件

    http://blog.csdn.net/rosanu_blog/article/details/8550723 http://www.bkjia.com/jQuery/449193.html < ...

  7. 自定义SWT控件二之自定义多选下拉框

    2.自定义下拉多选框 package com.view.control.select; import java.util.ArrayList; import java.util.HashMap; im ...

  8. Vue.js 多选列表(Multi-Select)组件

    搬运公众号早前文章 多选列表 (Multi-Select) 是一种将所有选项列出,并允许用户利用 Ctrl/Shift 键进行多选的 UI 元素.这是一种常见的设计元素.有时候为了节省空间,我们会将选 ...

  9. sharepoint 2010自定义访问日志列表设置移动终端否和客户端访问系统等计算列的公式

    上个月本人开发和上线了一个在SharePoint 2010上基于HTML5的移动OA网站,后端服务采用自定义的基于AgilePoint工作流引擎的Sharepoint Web服务,前端主要采用Jque ...

随机推荐

  1. Java之equals和==详解

    两者的区别: A:== 基本类型:比较的是值是否相同 引用类型:比较的是地址值是否相同 B:equals() 只能比较引用类型. 默认情况下,比较的是地址值是否相同,因为我们可以看源代码可以看到,在O ...

  2. JAVA面向对象-----封装

    我们日常使用的电脑主机,把cpu.内存.主板等等都封装到机箱里面去.假如没有机箱的话的出现什么问题,主机.主板全部都散落在一处,然后开机没有开机按钮,那么需要我们直接操作接跳线才能把电脑开启.这样子的 ...

  3. iOS开发之自己封装的提示框(警告框)样式BHAlertView

    最近需要使用到提示框(警告框)进行信息的展示和提醒,所以进行了一个类的封装,想用Swift调用此OC文件,但是发现有些困难,所以暂时先把OC代码进行展示,随后再好好研究一下在Swift中的使用. 对于 ...

  4. TCP连接建立系列 — 客户端发送SYN段

    主要内容:客户端调用connect()时的TCP层实现. 内核版本:3.15.2 我的博客:http://blog.csdn.net/zhangskd connect的TCP层实现 SOCK_STRE ...

  5. Linux/Unix--设备类型

          在Linux以及所有的Unix系统中,设备被分为以下三种类型:       块设备       字符设备       网络设备        块设备通常写为 blkdev ,它是可以寻址的 ...

  6. Java基础----Java---集合框架---泛型、泛型方法、静态方法泛型、泛型接口、泛型限定、泛型类

    泛型:jdk1.5后的新特性,用于解决安全问题,是一个安全机制. 好处: 1.将运行时的异常出现问题classcastException.转移到了编译时期.方便程序员调试解决问题,让运行事情问题减少, ...

  7. UNIX网络编程——关于socket阻塞与非阻塞情况下的recv、send、read、write返回值

    1.阻塞模式与非阻塞模式下recv的返回值各代表什么意思?有没有 区别?(就我目前了解阻塞与非阻塞recv返回值没有区分,都是 <0:出错,=0:连接关闭,>0接收到数据大小,特别:返回 ...

  8. xml特殊字符处理 如&

     写了个request2XML的方法,每当数据中有'<'.'&'符号时,封装的XML就无法解析.发现了XML里的CDATA属性,问题迎刃而解!在XML文档中的所有文本都会被解析器解析 ...

  9. 05_NoSQL数据库之Redis数据库:Redis的常用命令,键值相关命令和服务器相关命令

     Redis常用命令 Redis提供了丰富的命令对数据库和各种数据库类型进行操作,这些命令可以再Linux终端使用. 键值相关命令: Keys:返回满足给定pattern的所有key 用表达式*表 ...

  10. 最简单的基于FFmpeg的视频编码器-更新版(YUV编码为HEVC(H.265))

    ===================================================== 最简单的基于FFmpeg的视频编码器文章列表: 最简单的基于FFMPEG的视频编码器(YUV ...