• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - TableView 的 textLabel 高度根据内容

[复制链接]
菜鸟教程小白 发表于 2022-12-11 17:16:39 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我制作了一个折叠的 TableView。 tableView 的标签大小不会根据内容增加。我已经设置了 WordWrap 和 Lines = 0 但它仍然无法正常工作。 我正在使用 2 个 tableView 单元格来制作折叠 View 。

extension UIView {
func rotate(toValue: CGFloat, duration: CFTimeInterval = 0.2, completionDelegate: AnyObject? = nil) {
    let rotateAnimation = CABasicAnimation(keyPath: "transform.rotation")
    rotateAnimation.toValue = toValue
    rotateAnimation.duration = duration
    rotateAnimation.removedOnCompletion = false
    rotateAnimation.fillMode = kCAFillModeForwards

    if let delegate: AnyObject = completionDelegate {
        rotateAnimation.delegate = delegate
    }
    self.layer.addAnimation(rotateAnimation, forKey: nil)
}
}

class CollapsibleTableViewController: UITableViewController {
struct Section {
    var name: String!
    var items: [String]!
    var collapsed: Bool!

    init(name: String, items: [String], collapsed: Bool = false) {
        self.name = name
        self.items = items
        self.collapsed = collapsed
    }
}

var sections = [Section]()

override func viewDidLoad() {
    super.viewDidLoad()

    sections = [Section(name: "TEXT OVER HERE", items: ["TEXT OVER HERE."])]
}

override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
    return sections.count
}

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return (sections[section].collapsed!) ? 0 : sections[section].items.count
}

override func tableView(tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
    let header = tableView.dequeueReusableCellWithIdentifier("header") as! CollapsibleTableViewHeader

    header.toggleButton.tag = section
    header.titleLabel.text = sections[section].name
    header.toggleButton.rotate(sections[section].collapsed! ? 0.0 : CGFloat(M_PI_2))
    header.toggleButton.addTarget(self, action: #selector(CollapsibleTableViewController.toggleCollapse), forControlEvents: .TouchUpInside)

    return header.contentView
}

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCellWithIdentifier("cell") as UITableViewCell!

    cell.textLabel?.lineBreakMode = NSLineBreakMode.ByWordWrapping
    cell.textLabel?.numberOfLines = 0
    cell.textLabel?.text = sections[indexPath.section].items[indexPath.row]



    return cell
}

//
// MARK: - Event Handlers
//
func toggleCollapse(sender: UIButton) {
    let section = sender.tag
    let collapsed = sections[section].collapsed

    // Toggle collapse
    sections[section].collapsed = !collapsed

    // Reload section
    tableView.reloadSections(NSIndexSet(index: section), withRowAnimation: .Automatic)
}

}

enter image description here



Best Answer-推荐答案


试试这个代码:

 func tableView(tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {

    var lblSectionName: UILabel = UILabel()
    lblSectionName.text = self.sectionNames[section]
    lblSectionName.numberOfLines = 0
    lblSectionName.lineBreakMode = .ByWordWrapping
    lblSectionName.sizeToFit()
    return lblSectionName.frame.size.height
}

func tableView(tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
    var lblSectionName: UILabel = UILabel()
    lblSectionName.text = self.sectionNames[section]
    lblSectionName.numberOfLines = 0
    lblSectionName.lineBreakMode = .ByWordWrapping
    lblSectionName.sizeToFit()
    return lblSectionName
}

关于ios - TableView 的 textLabel 高度根据内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38971081/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap