不同UIStackView的子视图之间的等高约束
创始人
2025-01-09 19:36:08
0

要实现不同UIStackView的子视图之间的等高约束,可以使用Auto Layout来实现。以下是一个使用代码示例的解决方法:

首先,创建多个UIStackView,并将它们添加到父视图中:

// 创建父视图
let containerView = UIView()
containerView.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(containerView)

// 创建第一个UIStackView
let stackView1 = UIStackView()
stackView1.translatesAutoresizingMaskIntoConstraints = false
stackView1.axis = .vertical
containerView.addSubview(stackView1)

// 创建第二个UIStackView
let stackView2 = UIStackView()
stackView2.translatesAutoresizingMaskIntoConstraints = false
stackView2.axis = .vertical
containerView.addSubview(stackView2)

// 建立父视图和子视图的约束
containerView.topAnchor.constraint(equalTo: view.topAnchor, constant: 20).isActive = true
containerView.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: 20).isActive = true
containerView.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: -20).isActive = true
containerView.bottomAnchor.constraint(equalTo: view.bottomAnchor, constant: -20).isActive = true

// 建立第一个UIStackView的约束
stackView1.topAnchor.constraint(equalTo: containerView.topAnchor).isActive = true
stackView1.leadingAnchor.constraint(equalTo: containerView.leadingAnchor).isActive = true
stackView1.trailingAnchor.constraint(equalTo: containerView.trailingAnchor).isActive = true

// 建立第二个UIStackView的约束
stackView2.topAnchor.constraint(equalTo: stackView1.bottomAnchor, constant: 20).isActive = true
stackView2.leadingAnchor.constraint(equalTo: containerView.leadingAnchor).isActive = true
stackView2.trailingAnchor.constraint(equalTo: containerView.trailingAnchor).isActive = true
stackView2.bottomAnchor.constraint(equalTo: containerView.bottomAnchor).isActive = true

然后,创建每个UIStackView的子视图,并添加到对应的UIStackView中:

// 创建第一个UIStackView的子视图
let label1 = UILabel()
label1.translatesAutoresizingMaskIntoConstraints = false
label1.text = "Label 1"
stackView1.addArrangedSubview(label1)

let label2 = UILabel()
label2.translatesAutoresizingMaskIntoConstraints = false
label2.text = "Label 2"
stackView1.addArrangedSubview(label2)

// 创建第二个UIStackView的子视图
let button1 = UIButton()
button1.translatesAutoresizingMaskIntoConstraints = false
button1.setTitle("Button 1", for: .normal)
stackView2.addArrangedSubview(button1)

let button2 = UIButton()
button2.translatesAutoresizingMaskIntoConstraints = false
button2.setTitle("Button 2", for: .normal)
stackView2.addArrangedSubview(button2)

这样就实现了不同UIStackView的子视图之间的等高约束。子视图的高度将根据其中最高的子视图自动调整。

相关内容

热门资讯

十分钟了解!牌乐门打盾包赢(辅... 十分钟了解!牌乐门打盾包赢(辅助挂)都是有挂(专业辅助必胜教程)-哔哩哔哩;牌乐门打盾包赢是一项牌乐...
第7分钟了解!大赢家挂机软件(... 第7分钟了解!大赢家挂机软件(辅助挂)一向有挂(专业辅助透明挂教程)-哔哩哔哩相信很多朋友都在电脑上...
1分钟了解!福建老友麻将有挂的... 1分钟了解!福建老友麻将有挂的(辅助挂)先前存在有挂(专业辅助辅助教程)-哔哩哔哩;亲,有的,ai轻...
第四分钟了解!老友广东麻将插件... 第四分钟了解!老友广东麻将插件(辅助挂)从来是有挂(专业辅助黑科技教程)-哔哩哔哩;1、让任何用户在...
第七分钟了解!友空互娱麻将有猫... 第七分钟了解!友空互娱麻将有猫腻(辅助挂)固有存在有挂(专业辅助大神讲解)-哔哩哔哩;友空互娱麻将有...
八分钟了解!中至510k技巧(... 八分钟了解!中至510k技巧(辅助挂)好像真的是有挂(专业辅助大神讲解)-哔哩哔哩;中至510k技巧...
3分钟了解!天天爱掼蛋辅助(辅... 3分钟了解!天天爱掼蛋辅助(辅助挂)一直有挂(专业辅助攻略教程)-哔哩哔哩;最新版2026是一款经典...
第4分钟了解!兴动互娱有免费辅... 第4分钟了解!兴动互娱有免费辅助器(辅助挂)素来真的是有挂(专业辅助揭秘攻略)-哔哩哔哩;第4分钟了...
第六分钟了解!乐达踢坑有挂(辅... 第六分钟了解!乐达踢坑有挂(辅助挂)最初是真的有挂(专业辅助扑克教程)-哔哩哔哩;1、德州乐达踢坑有...
第9分钟了解!七千游戏可以开挂... 第9分钟了解!七千游戏可以开挂(辅助挂)确实存在有挂(专业辅助力荐教程)-哔哩哔哩;亲真的是有正版授...