如何根据其内容调整UIStackView的大小?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何根据其内容调整UIStackView的大小?相关的知识,希望对你有一定的参考价值。

我希望有一个类似于<Table> html标签的行为,在这种意义上,框架的大小根据其内容而定。

在我的上下文中,我使用UIStackView作为UITableViewCell的内容视图。由于单元格中的项目是各种信息,因此单元格的最终高度应该是可变的。

我的策略是以编程方式将单元格构建为具有.Vertical轴的UIStackView,如下面的代码片段所示:

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)

    let sv = UIStackView(frame: tableview.frame)
    sv.axis = .Vertical
    cell.addSubview(sv)
    for i in information {
        let l = UILabel()
        l.text = i
        sv.addSubViewAndArrange(l)
    }

    return cell
}

不幸的是,单元格大小不适应内容,因此我必须自己设置单元格高度,如下所示:

func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
    return cellHeight     // a constant
}

我怎么能解决这个问题?

答案

UIStackView旨在根据内容增加其大小。为了使其起作用,您需要在UIStackViewUITableViewCell之间设置约束。例如,这是约束在界面构建器中的样子:

enter image description here enter image description here

如果你喜欢在代码中设置约束,那也应该有效。

为了证明这将起作用,我有cellForRowAt函数。基本上,它在UILabel中放置了一些UIStackView,标签数量取决于行号。

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "TableviewCell", for: indexPath) as! TableviewCell
    for i in 1...indexPath.row + 1 {
        let label = UILabel()
        label.text = "Row (indexPath.row), Label (i)"
        cell.stackView.addArrangedSubview(label)
    }
    return cell
}

这是最终结果:

https://github.com/yzhong52/AutosizeStackview

以上是关于如何根据其内容调整UIStackView的大小?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Xcode 中调整 UIStackView 的子视图大小?

如何使用 UIStackView 按比例调整大小?

带有 2 个 UILabel 的 UIStackview 可以根据内容动态调整吗?

如何根据内容动态制作 Swift UIStackView 大小?

当 UIStackView 更改其排列的子视图时,UITableViewCell 不会调整大小

UIStackview 隐藏标签时不调整大小