UIStackView 是非常方便的自動布局控件驹暑,但是有個大坑,可能就我自己不知道
let stackView = UIStackView(frame: self.view.bounds)
stackView.backgroundColor = .white
stackView.axis = .vertical
stackView.distribution = .equalSpacing
stackView.alignment = .center
self.view.addSubview(stackView)
for _ in 0...5 {
let label = UILabel()
// label.frame.size = CGSize(width: 200, height: 100)
label.text = "jjkkkjkjkjk"
label.backgroundColor = .red
stackView.addArrangedSubview(label)
}
然鵝
let stackView = UIStackView(frame: self.view.bounds)
stackView.backgroundColor = .white
stackView.axis = .vertical
stackView.distribution = .equalSpacing
stackView.alignment = .center
self.view.addSubview(stackView)
for _ in 0...5 {
let label = UILabel()
// label.frame.size = CGSize(width: 200, height: 100)
// label.text = "jjkkkjkjkjk"
label.backgroundColor = .red
stackView.addArrangedSubview(label)
}
總結(jié)(經(jīng)過測試并我瞎猜瓷们,相關(guān)代碼就不上了)
- stackView 是容器界牡,設(shè)置內(nèi)部子控件 size 需要使用約束
- stackView 里面對 label 做了 sizeToFit() 操作
- stackView 如果需要空白占位,請用 UILabel钦椭,并設(shè)置 text 為 “ ”拧额,就 ok 了
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者