表格视图单元格的动态高度会扩展,但是显示空视图。
创始人
2024-12-10 05:30:34
0

要解决表格视图单元格的动态高度会扩展但显示为空视图的问题,可以按照以下步骤进行操作:

  1. 确保表格视图的代理方法中已经正确实现了计算单元格高度的方法,并且返回了正确的高度值。

  2. 在单元格的布局代码中,设置自动布局约束以适应内容的动态高度。可以使用自动布局库如SnapKit或使用原生的autolayout属性。

  3. 在单元格的布局代码中,确保设置了内容视图的约束,以确保内容视图能够扩展以适应内容的高度。

  4. 如果单元格的内容是根据异步加载的数据来确定的,可以在加载数据完成后,调用表格视图的reloadData方法来刷新表格视图的布局。

以下是一个示例代码,展示如何解决表格视图单元格动态高度扩展但显示为空视图的问题:

class MyTableViewController: UITableViewController {
    var data: [String] = [] // 假设这是表格视图的数据源

    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.register(MyTableViewCell.self, forCellReuseIdentifier: "Cell")
        tableView.rowHeight = UITableView.automaticDimension
        tableView.estimatedRowHeight = 100
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return data.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! MyTableViewCell
        cell.textLabel?.text = data[indexPath.row]
        return cell
    }

    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return UITableView.automaticDimension
    }
}

class MyTableViewCell: UITableViewCell {
    override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        setupViews()
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    func setupViews() {
        // 设置自动布局约束
        contentView.translatesAutoresizingMaskIntoConstraints = false
        contentView.topAnchor.constraint(equalTo: topAnchor).isActive = true
        contentView.leadingAnchor.constraint(equalTo: leadingAnchor).isActive = true
        contentView.trailingAnchor.constraint(equalTo: trailingAnchor).isActive = true
        contentView.bottomAnchor.constraint(equalTo: bottomAnchor).isActive = true

        // 设置内容视图的约束
        textLabel?.translatesAutoresizingMaskIntoConstraints = false
        textLabel?.topAnchor.constraint(equalTo: contentView.topAnchor, constant: 8).isActive = true
        textLabel?.leadingAnchor.constraint(equalTo: contentView.leadingAnchor, constant: 8).isActive = true
        textLabel?.trailingAnchor.constraint(equalTo: contentView.trailingAnchor, constant: -8).isActive = true
        textLabel?.bottomAnchor.constraint(equalTo: contentView.bottomAnchor, constant: -8).isActive = true
    }
}

在上面的示例代码中,MyTableViewController是表格视图的控制器,MyTableViewCell是表格视图的单元格。在viewDidLoad方法中,设置了表格视图的行高为自动维度,并且注册了单元格。在tableView(_:cellForRowAt:)方法中,设置了单元格的文本内容。在tableView(_:heightForRowAt:)方法中,返回了自动维度的行高。

MyTableViewCell中的setupViews方法中,设置了单元格内容视图的自动布局约束,确保内容视图能够扩展以适应内容的高度。

请注意,这只是一个示例代码,具体的实现可能会根据项目的需求而有所不同。

相关内容

热门资讯

二分钟发现!决战卡五星游戏辅助... 二分钟发现!决战卡五星游戏辅助器,poker world竟然真的是有挂,解密教程(有挂秘笈)1、决战...
必备攻略!旺旺福建麻将小程序麻... 必备攻略!旺旺福建麻将小程序麻将插件(透明挂)原来有挂(2024已更新)(哔哩哔哩);1、实时旺旺福...
微扑克有辅助挂!微扑克系统的发... 微扑克有辅助挂!微扑克系统的发牌速度有多快,微扑克有规律,玩家教程(有挂技巧);微扑克辅助插件是一个...
微扑克教程!wepoke算法(... 微扑克教程!wepoke算法(wepoke黑科技)WepokE(一直真的有挂);科技详细教程小薇《7...
9分钟科普!丽水都莱辅助器,A... 9分钟科普!丽水都莱辅助器,AApOKER切实有挂,2025新版总结(有挂神器)1、在丽水都莱辅助器...
重要通知!财神十三张开挂(透明... 重要通知!财神十三张开挂(透明挂)确实真的有挂(2023已更新)(哔哩哔哩)1、许多玩家不知道财神十...
微扑克辅助挂!微扑克系统发牌,... 1、微扑克辅助挂!微扑克系统发牌,WPK真是是有挂,专业教程(有挂解说)2、进入游戏-大厅左侧-新手...
wepower辅助器!wepo... 1、wepower辅助器!wepoke有软件(透明挂)wepOke(果真真的有挂);详细教程。2、w...
一分钟辅助!广西跑胡子有挂吗,... 一分钟辅助!广西跑胡子有挂吗,WEpoke其实是真的有挂,揭秘教程(有挂黑科技)1、广西跑胡子有挂吗...
一分钟带你了解!开心联盟金花怎... 一分钟带你了解!开心联盟金花怎么赢得多(透视)一直是真的有挂(2022已更新)(哔哩哔哩)1、下载好...