我的编程空间,编程开发者的网络收藏夹
学习永远不晚

iOS实现单元格折叠

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

iOS实现单元格折叠

本文实例为大家分享了iOS实现单元格折叠的具体代码,供大家参考,具体内容如下

折叠的核心是单元格的行数或列数实时变化

比较重要的步骤有:

设置数组 (可变数组,用于更新单元格内容)

调用方法 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { (来获取被选中的单元格) 比如我们定义这个tableView 叫做littletableView NSIndexPath *row = [self.littletableView indexPathForSelectedRow]; 上面这个代码用来获取 被选中的单元格的indexPath。

如何将选中的单元格内容与第一个单元格内容互换

比如我们现在有一个数组 1 2 3 4 5 我们选中了4 把4用[array insertObject: array [indexPath.row] atIndex:0];这个方法提到1的前面 变成了 4 1 2 3 4 5,此时第二个4的索引加了1 我们在删除时 [array removeObjectAtIndex:indexPath.row+1];索引要加1

改变tableView的大小 (这是非常重要的一点,如果你的tableView的frame不够,你即使给他设置10列10行,他也不会改变,因为一旦无法容纳,将不执行定义cell的方法(亲测)

下面是一步一步如何实现

在视图控制器的.h文件中,设置俩个UItableView的属性以及一个布尔值来判断单元格是否展开,设置一个可变数组保存单元格的标题信息。

在viewDidLoad里将他们初始化设置代理,设置tag值

在实现协议方法时,根据不同的tag值,对应不同方法体 例如:


- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
 if (tableView.tag == 101) {
 return 1;
 } else {
 if (cellisOpen == NO) {
  return 1;
 } else {
  return 4;
 }
 }
}

//注意没有设置代理,这些方法将不执行

在没有展开时,小单元格的行数为1(我们假设只有一组,行数发生变化),所以


- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
 if (tableView.tag == 101) {
 return 1;
 } else {
 return 4;
 }
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
 if (tableView.tag == 101) {
 return 1;
 } else {
 if (cellisOpen == NO) {
  return 1;
 } else {
  return 4;
 }
 }
}

在创建单元格的函数里,也要区分tag和布尔变量不同的情况的方法体

需要注意的是,在创建时,没有展开的单元格让其一直显示数组的第一个元素

接下来是最后一个很关键的函数


- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
NSLog(@"进入此函数");
 NSIndexPath *row = [self.littletableView indexPathForSelectedRow];
 [arrayrows insertObject:arrayrows[row.row] atIndex:0]; //arrayrows是存储单元格信息的数组
 NSLog(@"%@",arrayrows[row.row]); //我们来打印一下选中的单元格
 [arrayrows removeObjectAtIndex:row.row+1]; // 删除时选中的单元格索引加1
 for (int i = 0; i < 4; i++) {
 NSLog(@"%@",arrayrows[i]);
 }
 if (tableView.tag == 102) {
 if (cellisOpen == NO) {
 cellisOpen = YES; //更改折叠判断的布尔变量
 } else {
  cellisOpen = NO;//更改折叠判断的布尔变量
 }
 }
 if (cellisOpen == YES) {
 littletableView.frame = CGRectMake(280, 85, 120, 160); // 更改单元格的大小
 } else {
 littletableView.frame = CGRectMake(280, 85, 120, 40);
 }
 NSLog(@"%d",cellisOpen); //打印此时布尔值
 [littletableView reloadData]; // 更新被点击的单元格信息

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

iOS实现单元格折叠

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

iOS实现单元格折叠

本文实例为大家分享了iOS实现单元格折叠的具体代码,供大家参考,具体内容如下 折叠的核心是单元格的行数或列数实时变化 比较重要的步骤有: 1.设置数组 (可变数组,用于更新单元格内容) 2.调用方法 - (void)tableView:(U
2022-06-04

iOS实现折叠单元格

本文实例为大家分享了iOS实现折叠单元格的具体代码,供大家参考,具体内容如下 思路 点击按钮或cell单元格来进行展开收缩, 同时使用一个BOOL值记录单元格展开收缩状态。根据BOOL值对tableView的高度和button的image进
2022-05-29

iOS实现列表折叠效果

本文实例为大家分享了iOS实现列表折叠效果的具体代码,供大家参考,具体内容如下 实现列表折叠效果其实比较简单,点击列表头部的时候,把返回列表行数设为 0,就是收起列表;再次点击列表头部,显示列表的行数,就展开了列表。#import "Tab
2022-05-26

iOS实现图片折叠效果

本文实例为大家分享了iOS实现图片折叠效果的具体代码,供大家参考,具体内容如下 效果图:结构布局:拖两个UIImageView到控制器,设置相同的frame和图片,再拖一个大的UIImageView盖在上面,注意把大的imageView.u
2022-05-15

纯css怎样实现多级折叠菜单折叠树效果

这篇文章将为大家详细讲解有关纯css怎样实现多级折叠菜单折叠树效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、运用checkbox的checked值来判断下级栏目是否展开,CSS3的选择器中提供了:
2023-06-08

Vue表格隐藏行折叠效果如何实现

这篇“Vue表格隐藏行折叠效果如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue表格隐藏行折叠效果如何实现”文章吧
2023-07-06

iOS怎么使用UICollectionView实现拖拽移动单元格

这篇“iOS怎么使用UICollectionView实现拖拽移动单元格”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“iOS怎
2023-06-30

如何实现AmazeUI折叠面板

这篇文章主要介绍了如何实现AmazeUI折叠面板,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Amaze UI 是一个针对 HTML 5 开发的轻量级、模块化、移动优先的跨屏
2023-06-09

小程序如何实现多折叠展开菜单

这篇文章主要讲解了“小程序如何实现多折叠展开菜单”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“小程序如何实现多折叠展开菜单”吧!小程序实现多折叠展开菜单效果展示:  开始正题  上方Nav 
2023-06-26

css折叠外边距怎么实现

这篇文章主要介绍“css折叠外边距怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“css折叠外边距怎么实现”文章能帮助大家解决问题。先看一个简单示例: