일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- clean architecture
- collectionview
- ribs
- Xcode
- HIG
- combine
- 애니메이션
- uiscrollview
- rxswift
- UITextView
- swift documentation
- MVVM
- RxCocoa
- tableView
- ios
- Observable
- uitableview
- Clean Code
- 리펙토링
- UICollectionView
- Protocol
- 리펙터링
- map
- Refactoring
- Human interface guide
- 스위프트
- 클린 코드
- swiftUI
- 리팩토링
- SWIFT
- Today
- Total
목록Viper (2)
김종권의 iOS 앱 개발 알아가기
RIBs 아이디어 view가 아닌 business logic 중심 구조 state변화는 view가 아닌 business logic에서 관리 하나의 화면이 여러 ViewController로 이루어질 수 있다는 점이 존재 State관리는 scope를 이용하여 관리 (isolation) 모듈화에 의해 co-working에 유리: dependency가 제대로 inject되어 있다면 각 RIB을 합치기 쉬운 장점 RIB - 6개의 컴포넌트로 이루어진 하나의 기능 단위 (Required) Router: RIB이 어떻게 attach, detach될 것인지 (animation) Interactor: 비즈니스 로직 관리, 어떤 RIB들을 attach, detach 할지 명령 Builder: RIB 생성 (Mock에 유리..
uber가 RIBs를 만든 이유 - 모듈화 MVC를 사용할 때 새로운 기능이 늘어나며 앱의 복잡성 증가 모듈이 증가할수록, 테스트 하기 점점 어려워지는 현상 4년동안 MVC패턴 사용 -> 관리하기가 힘든 scale (하나의 ViewController파일에 300줄 -> 3000줄) massive view controllers (비즈니스 로직, 데이터 변경, 데이터 검증, 네트워크 로직, 라우팅 로직) 테스트가 어려운 구조 (if-else문으로 테스트) VIPER 아키텍처 View Interactor: 비즈니스 로직포함, API나 DB로 Data르 받아서 Entity(모델) 생성 Presenter: View에서 유저 앣견을 받고, Interactor에 data를 요창하여 VIew에 그려주는것을 다시요청 E..