티스토리 뷰
728x90
오늘은 개인 프로젝트에 MVVM을 적용해보면서
dataBinding을 할때
Observable이라는 class의 동작 방식을 공부해 보려고 합니다.
가즈아!
아래는 MVVM을 사용하고 데이터 바인딩을 해보셨다면 한번쯤 보셨을 코드입니다.
이런형태가 있구나 하면서 슥 보세요
설명은 아래서 !
class Observable<T> {
// 3
var listener: ((T) -> Void)?
// 2
var value: T {
didSet {
self.listener?(value)
}
}
// 1
init(_ value: T) {
self.value = value
}
// 4
func bind(listener: @escaping (T) -> Void) {
listener(value)
self.listener = listener
}
}
목적
Rx나 Combine을 사용하지 않았을때
View와 ViewModel 사이에서 지정된 프로퍼티의 값이 바뀔때마다 View에 변화를 주고싶을때 사용 합니다.
데이터 바인딩 이라고 해요.
이제부터 하나씩 뜯어봅시다.
데이터 바인딩을 할때 사용되는 로직의 예는 아래와 같습니다.
(상황)
ViewModel의 titleLabel의 값이 바뀌면, ViewController에 있는 titleLabel을 바꿔주려함. (View는 ViewModel 바라기기 때문)
ViewController
class ViewController: UIViewController {
private lazy var titleLabel: UILabel = {
let label = UILabel()
return label
}()
let viewModel = ViewModel()
// 데이터 바인딩 하는곳
override func viewDidLoad() {
viewModel.titleLabel.bind { [weak self] text in
DispatchQueue.main.async {
self?.titleLabel.text = text
}
}
}
}
ViewModel
class ViewModel {
let titleLabel: Observable<String> = Observable("")
이제 Observable을 볼게요.
주석으로 동작하는 순서 설명을 남겨놨습니다.
Observable
class Observable<T> {
// 1. 값을 value에 초기화 합니다.
init(_ value: T) {
self.value = value
}
}
class Observable<T> {
// 3. listener가 호출되면 2번에서 받은 값을 전달합니다.
var listener: ((T) -> Void)?
// 2. 값이 바뀐 직후, listener에 해당 값을 전달합니다.
var value: T {
didSet {
self.listener?(value)
}
}
init(_ value: T) {
self.value = value
}
}
class Observable<T> {
var listener: ((T) -> Void)?
var value: T {
didSet {
self.listener?(value)
}
}
init(_ value: T) {
self.value = value
}
// VC에서 bind가 호출되면
func bind(listener: @escaping (T) -> Void) {
listener(value) // 4. listener에 저장 했던 값 전달
self.listener = listener // 5. 추후 didSet에서 실행하기 위해 listener의 값을 self.listener에 할당
}
}
728x90
'iOS' 카테고리의 다른 글
[Swift] compactMap, flatMap (0) | 2022.09.01 |
---|---|
[Swift] 메모리 안정성 (Memory Safety) (0) | 2022.08.25 |
[Swift] Protocol(프로토콜) - protocol extension(프로토콜 확장) (0) | 2022.08.12 |
[Swift] Protocol - 타입 프로토콜, 위임 (0) | 2022.08.10 |
[iOS] Responder Chain, FirstResponder (0) | 2022.07.17 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- Swift final
- Swift
- Swift joined
- Swift init
- Class
- Swift joined()
- Swift 내림차순
- swift programmers
- swift reduce
- Swift 프로그래머스
- ios
- iOS error
- Swift RIBs
- Swift inout
- swift protocol
- Swift Leetcode
- CS 네트워크
- 2023년 회고
- RTCCameraVideoCapturer
- Swift 알고리즘
- Swift ModernRIBs
- 원티드 프리온보딩
- swift property
- Swift 프로퍼티
- removeLast()
- Swift Error Handling
- RIBs tutorial
- swift (programmers)
- Combine: Asynchronous Programming with Swift
- swift 고차함수
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함