SwiftUI+TCA+Combine

PropertyWrapper의 projectedValue

clamp 2024. 2. 26. 16:00

프로퍼티래퍼에대한 정보는 아래 포스팅에 정리되어있습니다.

 

https://clamp-coding.tistory.com/396

 

projectedValue

 

SwiftUI에서 @State, @Binding, @Published등의 프로퍼티 래퍼들은 각각의 *projected value(투영값)을 가집니다.

이 투영값은 프로퍼티 래퍼가 제공하는 추가 기능에 접근할 수 있도록 해주는데, 특히 바인딩이나 다른 형태의 상태관리를 위한 인터페이스 역할을 합니다. 이는 SwiftUI가 관리하는 변수의 "특별한 버전"을 의미합니다. 해당 변수를 UI컴포넌트와 연결하거나 변수의 변화를 감시하는 등의 추가적인 작업을 할 수 있게 됩니다.

ProjectedValue는  해당 프로퍼티의 "추가기능"에 접근할 수 있는 방법입니다. '$'기호를 사용하여 해당 값에 접근할 수 있으며, 주로 바인딩을 생성하거나, 특정 상태의 변화를 다루는데 사용됩니다.

 

사용방법

정의: PropertyWrapper 내부의 projectedValue를 정의합니다

사용: $로 선언한 변수명으로 접근합니다.

 

ex

정의:

@propertyWrapper
struct UserDefault<T> {
    let key: String
    let defaultValue: T
    var storedValue: Bool = false // 저장 성공 여부

    var wrappedValue: T {
        get {
            UserDefaults.standard.object(forKey: key) as? T ?? defaultValue
        }
        set {
            UserDefaults.standard.set(newValue, forKey: key)
            storedValue = true // 값이 저장되면 true로 업데이트
        }
    }

    var projectedValue: Bool {
        storedValue
    }
}

 

사용: 

class Settings: ObservableObject {
    @UserDefault(key: "isDarkMode", defaultValue: false)
    var isDarkMode: Bool

    func checkStorageStatus() {
        print($isDarkMode ? "저장 성공" : "저장 실패")
    }
}