일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Design Pattern
- Functional Programming
- 추상팩토리패턴
- 빌터패턴
- builderPattern
- 디자인패턴
- ㅋㅁ
- Observer Pattern
- 함수형프로그래밍
- designPattern
- F
- 옵저버 패턴
- Abstract Factory
- PrototypePattern
- 팩토리 메소드
- El
- 프로토타입 패턴
- 디자인패턴 #
- Singleton
- factory method
- ㅓ
- Kotlin
- r
- 코틀린
- 싱글톤
- a
- 추상 팩토리
- Today
- Total
오늘도 더 나은 코드를 작성하였습니까?
Compose UI Event 다루기 본문
UI Event란???
- UI Layer에서 처리 되어야 하는 작업
- User Event / ViewModel Event 2종류가 존재한다
User Event
예를 들어 사용자가 "새로고침 버튼을 누르면 화면의 리스트를 갱신" 한다고 해보자
사용자의 행동(새로고침 버튼 누름)으로 UI(화면의 리스트) 갱신하는것은 Business logic에 해당하기 때문에 ViewModel에 위임하여 처리합니다.
ViewModel Event
예를들면, 네트워크 연결이 끊어졌다는 던가, 데이터를 불러오다가 에러가 발생(새로고침 실패)하였다든가, 하는 상황을 생각해 보자!
이런한 이벤트들은 화면에 알림(toast, dialog 등)을 통하여 표시되어진다.
이벤트는 UI State로 모델링되어야 하며, 항상 UI State를 업데이트 한다.
1. 요청이 실패하면, 새로운 에러 메세지를 UI State에 반영한다.
2. errorMessage를 가진 UI State 변화에 따라 UI 변경(toast, dialog 등)
3. UI는 ViewModel에게 메세지가 사라졌음을 알림.
4. errorMessage가 없는 UI State가 반영되여 UI가 그려짐.
UI State로 모델링하고, 관찰 가능한 StateFlow에 담아서 노출한다.
새로고침 버튼을 누르면 State를 로딩으로 변경하고, viewModelScope에서 비동기로 비지니로직을 처리한다.
성공을 하면, 데이터를 담고 로딩 아님으로 상태를 변경한다.
실패를 하면, 에러메세지를 담고 로딩 아님으로 상태를 변경한다.
error 메세지의 존재 여부에 따라 메세지를 보여주고, onErrorDismiss를 통해 uiState를 변경한다.
'Compose' 카테고리의 다른 글
안드로이드 컴포즈 네비게이션1 기초 Compose navigation Basic1 (1) | 2024.12.01 |
---|---|
Event에 따른 UI State 처리방법 (1) | 2024.11.17 |
Compose 상태와 상태홀더 다루기 State & StateHolder (0) | 2024.11.17 |
재사용 가능한 Composable 함수 만들기. (0) | 2024.11.05 |
Compose UI(Composable) 생명주기 (3) | 2024.09.26 |