微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

iOS 7 beginUpdates endUpdates不一致

编辑:
此答案的解决方案与iOS7有关,有时返回NSIndexPath,有时返回NSMutableIndexPath.该问题与begin / endUpdates并不真正相关,但希望该解决方案能够帮助其他人.

全部 – 我在iOS 7上运行我的应用程序,我遇到了UITableView的beginUpdates和endUpdates方法的问题.

我有一个tableview,需要在触摸时更改单元格的高度.以下是我的代码

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {

        // If our cell is selected,return double height
        if([self cellIsSelected:indexPath]) {
            return 117;
        }

        // Cell isn't selected so return single height
        return 58;

}

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{

        ChecklistItemCell *cell = (ChecklistItemCell *)[self.tableview cellForRowAtIndexPath:indexPath];
        [cell.decreaseButton setHidden:NO];
        [cell.increaseButton setHidden:NO];

        // Toggle 'selected' state
        BOOL isSelected = ![self cellIsSelected:indexPath];

        DLog(@"%@",selectedindexes);

        DLog(@"is selected: %@",isSelected ? @"yes":@"no");
        // Store cell 'selected' state keyed on indexPath
        NSNumber *selectedindex = @(isSelected);
        selectedindexes[indexPath] = selectedindex;

        [tableView beginUpdates];
        [tableView endUpdates];

}

beginUpdates和endUpdates方法的工作非常不一致. didSelectRowAtIndexPath方法在每次触摸时被正确调用(我认为首先UI被阻止),并且selectedindexes正确地存储交替值.问题是,有时我触摸表格单元格并且所有方法都被正确调用,但单元格高度不会改变.有谁知道发生了什么事?

解决方法

iOS7中的行为发生了变化,其中索引路径有时是NSIndexPath的实例,有时是UIMutableIndexPath的实例.问题是这两个类之间的isEqual总是会返回NO.因此,您无法可靠地将索引路径用作字典键或在依赖isEqual的其他方案中使用.

我可以想到几个可行的解决方案:

>编写一个始终返回NSIndexPath实例并使用它生成键的方法

- (NSIndexPath *)keyForIndexPath:(NSIndexPath *)indexPath
{
    if ([indexPath class] == [NSIndexPath class]) {
        return indexPath;
    }
    return [NSIndexPath indexPathForRow:indexPath.row inSection:indexPath.section];
}

>按数据识别行,而不是索引路径.例如,如果您的数据模型是Nsstring数组,请使用该字符串作为selectedindexes映射的键.如果您的数据模型是NSManagedobjects数组,请使用objectID等.

我在我的代码中成功使用了这两种解决方案.

编辑修改后的解决方案(1)基于@ rob建议返回NSIndexPaths而不是Nsstrings.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


当我们远离最新的 iOS 16 更新版本时,我们听到了困扰 Apple 最新软件的错误和性能问题。
欧版/美版 特别说一下,美版选错了 可能会永久丧失4G,不过只有5%的概率会遇到选择运营商界面且部分必须连接到iTunes才可以激活
一般在接外包的时候, 通常第三方需要安装你的app进行测试(这时候你的app肯定是还没传到app store之前)。
前言为了让更多的人永远记住12月13日,各大厂都在这一天将应用变灰了。那么接下来我们看一下Flutter是如何实现的。Flutter中实现整个App变为灰色在Flutter中实现整个App变为灰色是非常简单的,只需要在最外层的控件上包裹ColorFiltered,用法如下:ColorFiltered(颜色过滤器)看名字就知道是增加颜色滤镜效果的,ColorFiltered( colorFilter:ColorFilter.mode(Colors.grey, BlendMode.
flutter升级/版本切换
(1)在C++11标准时,open函数的文件路径可以传char指针也可以传string指针,而在C++98标准,open函数的文件路径只能传char指针;(2)open函数的第二个参数是打开文件的模式,从函数定义可以看出,如果调用open函数时省略mode模式参数,则默认按照可读可写(ios_base:in | ios_base::out)的方式打开;(3)打开文件时的mode的模式是从内存的角度来定义的,比如:in表示可读,就是从文件读数据往内存读写;out表示可写,就是把内存数据写到文件中;
文章目录方法一:分别将图片和文字置灰UIImage转成灰度图UIColor转成灰度颜色方法二:给App整体添加灰色滤镜参考App页面置灰,本质是将彩色图像转换为灰度图像,本文提供两种方法实现,一种是App整体置灰,一种是单个页面置灰,可结合具体的业务场景使用。方法一:分别将图片和文字置灰一般情况下,App页面的颜色深度是24bit,也就是RGB各8bit;如果算上Alpha通道的话就是32bit,RGBA(或者ARGB)各8bit。灰度图像的颜色深度是8bit,这8bit表示的颜色不是彩色,而是256
领导让调研下黑(灰)白化实现方案,自己调研了两天,根据网上资料,做下记录只是学习过程中的记录,还是写作者牛逼