iOS 응용 (swift)
[iOS - SwiftUI] VStack, HStack을 사용할 때 주의할 점 (Stack 패딩, Stack 사이즈 고정)
jake-kim
2024. 12. 5. 01:42
VStack, HStack 사용 할 때 주의할 점
- VStack, HStack은 내부 콘텐츠 크기에 의해서, 자기 자신의 크기가 결정되는 컴포넌트
- 대부분 실수하는 것이 VStack, HStack에 패딩을 넣거나 사이즈를 고정하는 경우가 존재
ex) VStack에 width를 120으로 고정하는 경우
struct ContentView: View {
var body: some View {
VStack(alignment: .leading) {
Text("start")
VStack {
Text("1")
Text("2")
Text("3")
Text("4")
Text("5")
}
.frame(width: 120) // <-
.background(Color.green)
Text("end")
}
}
}
- 위 UI를 보면 정상적으로 120으로 고정된 것 같지만, 만약 내부 콘텐츠의 사이즈가 120보다 커지면 충돌이 발생하는데 이때 뷰가 복잡해지면 버그가 많이 생길 수 있으므로 주의할 것
- 만약 120으로 고정시키고 싶다면, frame(maxWidth:)를 사용
struct ContentView: View {
var body: some View {
VStack(alignment: .leading) {
Text("start")
VStack {
Text("1")
Text("2")
Text("3")
Text("4")
Text("5")
Text("1234567891234512345678")
}
.frame(maxWidth: 120)
.background(Color.green)
Text("end")
}
}
}
- 만약 120이상으로 하고 싶은 경우는 내부에 120width인 투명뷰를 넣어서 세팅
struct ContentView: View {
var body: some View {
VStack(alignment: .leading) {
Text("start")
VStack {
Color.clear
.frame(width: 120, height: 0)
Text("1")
Text("2")
Text("3")
Text("4")
Text("5")
}
.background(Color.green)
Text("end")
}
}
}
결론
- VStack, HStack 모두 내부 크기에 의해서 외부 크기가 결정되는 컴포넌트이며, 예외적으로 frame을 고정시키고 싶을땐 frame(maxWidth:)나 frame(maxHeight:) 함수를 사용하고 그게 아니라면 내부 콘텐츠에 투명 뷰를 넣어서 크기를 조절할 것