自定义UITtableViewCell的布局约束无法正常工作

时间:2017-01-03 12:02:07

标签: swift uitableview uilabel constraints

我创建了每个都带有UILabel的自定义UITableViewCell,但不能让标签显示在单元格左上角以外的任何地方looks like this

似乎没有应用约束,但他们被调用(到达断点)。我尝试用UIImageView替换UILabel并应用相同的约束但没有出现(即表视图单元格为空白)。

我错过了什么?

查看细胞:

import UIKit

class myTableViewCell: UITableViewCell {

    override init(style: UITableViewCellStyle, reuseIdentifier: String!) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        setupViews()
    }

    required init?(coder decoder: NSCoder) {
        super.init(coder: decoder)
    }

    let label: UILabel = {
        let label = UILabel()
        label.translatesAutoresizingMaskIntoConstraints = false
        label.font = UIFont.systemFont(ofSize: 16, weight: UIFontWeightLight)
        label.text = "Sample"
        label.backgroundColor = UIColor.red
        return label
    }()

    func setupViews () {
        addSubview(label)
        //add constraints
        let marginsGuide = self.contentView.layoutMarginsGuide
        label.leadingAnchor.constraint(equalTo: marginsGuide.leadingAnchor).isActive = true
        label.trailingAnchor.constraint(equalTo: marginsGuide.trailingAnchor).isActive = true
        label.topAnchor.constraint(equalTo: marginsGuide.topAnchor).isActive = true
        label.bottomAnchor.constraint(equalTo: marginsGuide.bottomAnchor).isActive = true
    }

}

查看控制器:

import UIKit

class myViewController: UIViewController, UITableViewDelegate, UITableViewDataSource  {

    var myTableView: UITableView = UITableView()

    var myArray = [Int]()

    override func viewDidLoad() {
        super.viewDidLoad()
        //... do stuff incl. loading data into my myArray
        let screenSize: CGRect = UIScreen.main.bounds
        self.myTableView.frame = CGRect(x: 0, y: 0, width: screenSize.width, height: screenSize.height)
        self.myTableView.delegate = self
        self.myTableView.dataSource = self
        self.myTableView.register(IngredientListTableViewCell.self, forCellReuseIdentifier: "cell")
        self.view.addSubview(myTableView)
    }

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

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = self.myTableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! myTableViewCell
        return cell
    }

}

1 个答案:

答案 0 :(得分:0)

更改此

addSubview(label)

到这个

contentView.addSubview(label)