iOS/SwfitUI

SwiftUI) ContentView 이해하기 (2/2) - ContentView 사용하기

소들이 2022. 4. 11. 20:42

 

안녕하세요!! 소들입니다 :D

이번엔 ContentView 이해하기 2편입니당!!!

1편이 생각보다 되게 내용이 깊고 어려웠어서.. 이해하기 힘들었을 거 같은데

(Opaque Types에 대해 아직 내용 추가할 게 산더미;;)

 

그 산만 잘 넘었다면 이번 포스팅은 매우 간단하고 쉽고 짧습니다! :)

가볍게 읽어주세요!!

모든 포스팅은 편의 말투로 합니다~!!

 

 

 

 

1. ContentView는 뭐 하는 애일까?

 

struct ContentViewView {
    var bodysome View {
        Text("Hello, world!")
            .padding()
    }
}

 

 

맨 처음 프로젝트를 생성하면 나오는 구조체잖음?

우리가 지금껏 ViewController 혹은 View에서 화면을 그리고

변수를 생성하고 어쩌고 하던 작업들을

ContentView라는 구조체의 부에서 한다고 생각하면 됨!!!

 

다만, 이때 View라는 것은 이전 포스팅에서 공부 했듯이,

 

 

 

 

프로토콜로 구현되어 있고, body라는 프로퍼티를 갖고 있음!!

(상속이 안 되는 구조체에서 채택하는 것을 보면 당연히 프로토콜임!)

 

따라서 View를 채택하고 있는

ContentView 구조체 안에 body라는 프로퍼티는 당연히 있어야 되고,

body가 바로 ContentView의 최상위 View의 역할을 하는 것임!!!

참고로 이 body는 연산 프로퍼티(computed property)로 구현하면 됨!!

 

맨 첨에 봤던 코드처럼,

ContentView에서 최상위 View 역할을 하는 body 안에 Text라는 것을 넣을 경우,

(Text는 SwiftUI에서의 Label이라고 생각하셈)

 

 

 

 

이렇게 화면에 View가 그려지게 되는 것임!!

그럼이제 ContentView의 몇 가지 속성에 대해 알아보자 :)

 

 

 

 

2. ContentView 이해하기

 

2-1. body는 단 한개의 View만 반환해야 한답니다

 

body 연산 프로퍼티는 단 "한 개"의 View만 리턴해야 함!

따라서 만약 다음과 같이 Text를 두개 쓸 경우,

 

 

struct ContentViewView {
    var bodysome View {
        Text("Hello, Sodeul!")
        Text("Hello, DeulSo!")
    }
}

 

 

시뮬레이터로 돌리면

 

 

아무 문제 없는데용?? 잘나오는데용??

싶겠지만,

 

 

 

 

프리뷰가 쌍둥이가 되고요 👼👼

 

따라서, 만약 이렇게 여러 개의 배를 배치하고 싶을 땐

차근차근 포스팅 할 예정인

Stack / Group 등등..을 사용해서

여러 개의 뷰들을 하나의 뷰로 감싸줘서 하나의 View로 리턴해야 함!!! 

 

 

 

 

이런 식으로!! :)

 

실제 위 코드에서 body의 타입은

VStack<TupleView<Text,Text>>으로 VStack이라는 하나의 View로 반환되는 것임!

다만 우린 위의 복잡한 타입에 대해 알 필요 없고 명시할 필요도 없다! 왜 와ㅏ이?

body가 some View 즉, 불투명 타입을 리턴하니까! 하하

 

 

 

2-2. ContentView에 변수나 상수를 추가하고 싶으면 어떻게 하나요?

 

원래 해주던 것 처럼 해주시면 됩니다ㅋㅎㅎㅋ

 

 

 

 

이런 식으루!!

body에서 물논 사용 가능 함 :)

 

 

 

2-3. View의 생애주기를 관리하고 싶다면 어떻게 하나요?

 

그.. UIKit으로 개발할 때 사용하는 View Controller의 생애주기 있잖음?

 

ViewDidAppear

ViewDidDisappear

...

 

등등.. 이런 거 어떻게 사용하냐면

 

onAppear

onDisappear

 

 라는 modifier를 이용하면 됨!! :)

 

 

struct ContentViewView {
    var name = "Sodeul"
    var bodysome View {
       VStack {
            Text("Hello, \(name)!")
            .onAppear {
                print("Text가 보입니다!!")
            }
            .onDisappear {
                print("Text가 사라집니다!!")
            }
        }
    }
}

 

 

위와 같이 modifier를 이용해서

onAppear / onDisappear를 달아줄 수 있음!!

 

 

 

 

실제 시뮬레이터로 실행시켜 보면,

이렇게 잘 작동 한답니다 :)

 

 

+ 참고로

위의 body 프로퍼티는 View가 생성되고 한 번만 만들어지는 게 아니라

View의 Life Cycle 동안 필요할 때마다 여러 번씩 새로 만들어져서 리턴

(이 부분에 대해선 나중 포스팅에서 볼게욥!)

 

그럼 성능에 ㄱㅐ문제있는 거 아닌가요? 싶겠지만,

SwiftUI에선 View 자체가 클래스가 아닌 구조체로 매우매우 가볍기 때문

말단 개발자인 우리가 걱정할 문제가 아니라고 한다^^;;

 

 

 

 

 

 

.

.

.

 

SwiftUI ContentView에 대해 이번엔 아주 가볍게 기본에 대해 알아보았으빈다

다음엔 어떤 내용일지 하하 고민좀 해보겠음

오타 및 잘못된 내용 피드백 대환영입니다!!