OC有masonry,swift有SnapKit。
熟悉masonry的同學上手SnapKit非常快,因為語法很像。
這里記錄一下常用的幾個方法:
先創建一個紅色view:
let redView = UIView()
self.view.addSubview(redView)
redView.backgroundColor = UIColor.red
創建約束
// 創建約束
redView.snp.makeConstraints { (make) in
// 距離上左下右各20
make.top.left.equalToSuperview().offset(20)
make.bottom.right.equalToSuperview().offset(-20)
}
更新約束
// 更新約束
redView.snp.updateConstraints { (make) in
// 距離底部100
make.bottom.equalTo(-100)
}
重新設置約束
// 重新設置約束
redView.snp.remakeConstraints { (make) in
// 距離四邊100
make.edges.equalTo(UIEdgeInsetsMake(100, 100, 100, 100))
}
label寬度自適應(不設置寬度即可)
// label寬度自適應(不設置寬度)
let label = UILabel()
self.view.addSubview(label)
label.text = "這是一個綠色label"
label.backgroundColor = UIColor.green
label.font = UIFont.systemFont(ofSize: 15)
label.snp.makeConstraints { (make) in
make.left.equalToSuperview()
make.height.equalTo(20)
make.bottom.equalTo(-60)
}
并排的兩個label,優先讓其中一個寬度自適應(別扯我)
// 并排的兩個label,優先讓右邊的label寬度自適應
// 左邊的label
let leftLabel = UILabel()
self.view.addSubview(leftLabel)
leftLabel.backgroundColor = UIColor.lightGray
leftLabel.text = "這是左邊的label"
leftLabel.font = UIFont.systemFont(ofSize: 12)
// 右邊的label
let rightLabel = UILabel()
self.view.addSubview(rightLabel)
rightLabel.backgroundColor = UIColor.orange
rightLabel.text = "這是右邊的label,優先寬度自適應內容"
rightLabel.font = UIFont.systemFont(ofSize: 12)
// 別扯我,謝謝(這就是右邊label優先寬度自適應的關鍵代碼)
rightLabel.setContentHuggingPriority(1000, for: UILayoutConstraintAxis.horizontal);
leftLabel.snp.makeConstraints { (make) in
make.left.equalToSuperview()
make.bottom.equalTo(-20)
make.height.equalTo(20)
}
rightLabel.snp.makeConstraints { (make) in
make.left.equalTo(leftLabel.snp.right)
make.bottom.height.equalTo(leftLabel)
make.right.equalToSuperview()
}
效果: