Accordion 表格单元格 - 用于展开和折叠 ios

Posted

技术标签:

【中文标题】Accordion 表格单元格 - 用于展开和折叠 ios【英文标题】:Accordion table cell - for expand and collapse ios 【发布时间】:2013-09-07 14:23:10 【问题描述】:

我正在尝试以手风琴单元格模式展开/折叠 tableview 单元格,这样,当用户点击行时,他们将通过扩展行高来获得单元格内所选行的详细描述。我有 2 个数组,'array' 和 'detailarray' 分别用于在 'cell.textLabel.text' 和 'cell.detailTextLabel.text' 单元格中显示它。现在最初我已将 'cell.detailTextLabel.hidden = YES' 设为隐藏,这样当用户点击该行时可以获得单元格的扩展文本。

我的代码,

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

    static NSString *CellIdentifier = @"Cell";
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];

    // Configure the cell...
    cell.textLabel.text=[array objectAtIndex:indexPath.row];
    cell.detailTextLabel.text=[detailarray objectAtIndex:indexPath.row];
    cell.detailTextLabel.hidden = YES;

    return cell;


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

    [tableView deselectRowAtIndexPath:indexPath animated:YES];
    NSLog(@"indexpath is %d", indexPath.row);
    selectedIndex = indexPath.row;
    isSearching = YES;

    [self.tableview beginUpdates];

    static NSString *CellIdentifier = @"Cell";
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];
    cell.textLabel.text=[array objectAtIndex:indexPath.row];
    cell.detailTextLabel.text=[detailarray objectAtIndex:indexPath.row];
    cell.detailTextLabel.hidden = NO;

    [self.tableview endUpdates];


- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath 
    if (isSearching && indexPath.row == selectedIndex)
           
        return 77;      
    
    return 44;    

现在我创建了一个有 4 行的 tableviewcell,当点击每一行时,我会得到所选行的扩展视图。 在运行时,我可以在单元格扩展时看到“detailarray”文本,但是当 didselectRowAtIndexPath 函数停止时它消失了,为什么会这样,任何人都可以在这方面帮助我。

【问题讨论】:

这是您的same question。您还可以使用以下教程进行演示; 1) Demo1 2) Demo2 3) Demo3 希望这会有所帮助。 【参考方案1】:

查看SubTable,它会为您处理展开/折叠。

如果您正在寻找在主要单元格下显示的单个详细信息单元格,您可以像这样实现委托方法:

- (NSInteger)numberOfChildCellsUnderParentIndex:(NSInteger)parentIndex 
    if (detailarray[parentIndex] contains content)
        return 1;
    else
        return 0;

并根据您的需要自定义单元格的高度和外观

【讨论】:

【参考方案2】:

选择单元格后,请记住其在 selectedIndex 属性中的索引(您必须创建一个)。

向表格视图添加函数:

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
    return indexPath.row == selectedIndex ? extendedHeight : normalHeight;

选择单元格后不要忘记重新加载tableView。

【讨论】:

实际上我可以获得单元格的扩展视图,问题是在选择 detailarray 显示的行时,一旦我停止按下该行,detailarray 文本就会消失,但扩展行保持不变高度为 100。

以上是关于Accordion 表格单元格 - 用于展开和折叠 ios的主要内容,如果未能解决你的问题,请参考以下文章

展开和折叠表格视图单元格

展开和折叠表格视图中的单元格

我们如何快速在表格视图底部添加展开和折叠单元格

展开和折叠所有表格视图单元格

如何通过单击根据其内容更改表格单元格的高度(折叠和展开)?

通过使用约束自行调整大小来展开和折叠 TableView 单元格