UITableView:单击按钮时如何动态更改单元格高度?
UITableView: How to change cell height dynamically when a button is clicked in it?
我有一个 UITableView,其中每个单元格都有一个按钮。
单击按钮时,单元格的高度将发生变化。
当然,整个tableview的高度也会随之改变。
我在长时间冲浪时找不到方法。
实现这一目标的优雅解决方案是什么?
调用函数- reloadRowsAtIndexPaths:withRowAnimation:
。实现函数 UITableViewDelegate
函数 - tableView:heightForRowAtIndexPath:
和 return 的新高度。
(请参阅 this answer. Kudos to Tapas Pal 以了解原始答案。我只是对其进行了更改以更适合您的问题。)
您将需要一个 BOOL
变量来告诉单元格它的高度应该与其他单元格不同。您还需要一个数字(在这里,我将使用 NSInteger
)变量,以便您可以增加正确单元格的高度。
BOOL shouldCellBeExpanded = NO;
NSInteger indexOfExpandedCell = -1;
然后,在您的 -tableView:cellForRowAtIndexPath:
方法中,将以下内容添加到您设计单元格的位置。您会将按钮标签设置为与其单元格的行相同,以便您知道要展开的单元格。此外,如果您需要向单元格中添加任何元素,可以在 if
语句中进行。
[[cell aButton] setTag:[indexPath row]];
if(shouldCellBeExpanded && [indexPath row] == indexOfExpandedCell)
{
// design your read more label here
}
移至按钮的 IBAction
。点击按钮时,UITableView
将重新加载按钮所在的单元格。 注意:如果您在 UITableView
中使用多个部分,则需要添加另一个数字变量来说明这一点。如果您需要帮助,请发表评论。
-(IBAction) aButtonTapped:(id)sender
{
UIButton *aButton = (UIButton *)sender;
indexOfExpandedCell = [aButton tag];
shouldCellBeExpanded = YES;
[[self tableView] beginUpdates];
[[self tableView] reloadRowsAtIndexPaths:@[[NSIndexPath indexPathForItem: indexOfExpandedCell inSection:0]] withRowAnimation:UITableViewRowAnimationAutomatic];
[[self tableView] endUpdates];
}
最后,在-tableView:heightForRowAtIndexPath:
方法中:
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if(shouldCellBeExpanded && [indexPath row] == indexOfExpandedCell)
return 200.0f; //Your desired height for the expanded cell
else
return 100.0f; //The other cells' height
}
它的作用是检查单元格是否需要扩展,如果是,则该单元格是否是当前要求高度值的单元格。如果是,则返回值为展开高度。没有的话就是原版的
我有一个 UITableView,其中每个单元格都有一个按钮。
单击按钮时,单元格的高度将发生变化。
当然,整个tableview的高度也会随之改变。
我在长时间冲浪时找不到方法。
实现这一目标的优雅解决方案是什么?
调用函数- reloadRowsAtIndexPaths:withRowAnimation:
。实现函数 UITableViewDelegate
函数 - tableView:heightForRowAtIndexPath:
和 return 的新高度。
(请参阅 this answer. Kudos to Tapas Pal 以了解原始答案。我只是对其进行了更改以更适合您的问题。)
您将需要一个 BOOL
变量来告诉单元格它的高度应该与其他单元格不同。您还需要一个数字(在这里,我将使用 NSInteger
)变量,以便您可以增加正确单元格的高度。
BOOL shouldCellBeExpanded = NO;
NSInteger indexOfExpandedCell = -1;
然后,在您的 -tableView:cellForRowAtIndexPath:
方法中,将以下内容添加到您设计单元格的位置。您会将按钮标签设置为与其单元格的行相同,以便您知道要展开的单元格。此外,如果您需要向单元格中添加任何元素,可以在 if
语句中进行。
[[cell aButton] setTag:[indexPath row]];
if(shouldCellBeExpanded && [indexPath row] == indexOfExpandedCell)
{
// design your read more label here
}
移至按钮的 IBAction
。点击按钮时,UITableView
将重新加载按钮所在的单元格。 注意:如果您在 UITableView
中使用多个部分,则需要添加另一个数字变量来说明这一点。如果您需要帮助,请发表评论。
-(IBAction) aButtonTapped:(id)sender
{
UIButton *aButton = (UIButton *)sender;
indexOfExpandedCell = [aButton tag];
shouldCellBeExpanded = YES;
[[self tableView] beginUpdates];
[[self tableView] reloadRowsAtIndexPaths:@[[NSIndexPath indexPathForItem: indexOfExpandedCell inSection:0]] withRowAnimation:UITableViewRowAnimationAutomatic];
[[self tableView] endUpdates];
}
最后,在-tableView:heightForRowAtIndexPath:
方法中:
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if(shouldCellBeExpanded && [indexPath row] == indexOfExpandedCell)
return 200.0f; //Your desired height for the expanded cell
else
return 100.0f; //The other cells' height
}
它的作用是检查单元格是否需要扩展,如果是,则该单元格是否是当前要求高度值的单元格。如果是,则返回值为展开高度。没有的话就是原版的