페이징 라이브러리 개요 Android Jetpack의 구성요소
Paging 라이브러리를 사용하면 로컬 저장소에서나 네트워크를 통해 대규모 데이터 세트의 데이터 페이지를 로드하고 표시할 수 있습니다. 이 방식을 사용하면 앱에서 네트워크 대역폭과 시스템 리소스를 모두 더 효율적으로 사용할 수 있습니다. Paging 라이브러리의 구성요소는 권장 Android 앱 아키텍처에 맞게 설계되었으며 다른 Jetpack 구성요소와 원활하게 통합되고 최고 수준으로 Kotlin을 지원합니다.
페이징 라이브러리를 사용하여 얻을 수 있는 이점
페이징 라이브러리에는 다음과 같은 기능이 있습니다.
- Paging된 데이터의 메모리 내 캐싱. 이렇게 하면 앱이 Paging 데이터로 작업하는 동안 시스템 리소스를 효율적으로 사용할 수 있습니다.
- 요청 중복 삭제 기능이 기본 제공되므로 앱에서 네트워크 대역폭과 시스템 리소스를 효율적으로 사용할 수 있습니다.
- 사용자가 로드된 데이터의 끝까지 스크롤할 때 구성 가능한
RecyclerView
어댑터가 자동으로 데이터를 요청합니다. - Kotlin 코루틴 및 플로뿐만 아니라
LiveData
및 RxJava를 최고 수준으로 지원합니다. - 새로고침 및 재시도 기능을 포함하여 오류 처리를 기본으로 지원합니다.
의견 보내기
제출하신 의견은 Jetpack을 개선하는 데 도움이 됩니다. 새로운 문제를 발견하거나 라이브러리 개선을 위한 아이디어가 있다면 Google에 알려 주세요. 새 문제를 제출하기 전에 이 라이브러리의 기존 문제를 확인하시기 바랍니다. 별표 버튼을 클릭하여 기존 문제에 투표할 수 있습니다.
의견 제출에 관한 자세한 내용은 Issue Tracker 문서를 참고하세요.
설정
페이징 구성요소를 Android 앱으로 가져오려면 앱의 build.gradle
파일에 다음 종속 항목을 추가하세요.
Groovy
dependencies { def paging_version = "3.3.2" implementation "androidx.paging:paging-runtime:$paging_version" // alternatively - without Android dependencies for tests testImplementation "androidx.paging:paging-common:$paging_version" // optional - RxJava2 support implementation "androidx.paging:paging-rxjava2:$paging_version" // optional - RxJava3 support implementation "androidx.paging:paging-rxjava3:$paging_version" // optional - Guava ListenableFuture support implementation "androidx.paging:paging-guava:$paging_version" // optional - Jetpack Compose integration implementation "androidx.paging:paging-compose:3.3.2" }
Kotlin
dependencies { val paging_version = "3.3.2" implementation("androidx.paging:paging-runtime:$paging_version") // alternatively - without Android dependencies for tests testImplementation("androidx.paging:paging-common:$paging_version") // optional - RxJava2 support implementation("androidx.paging:paging-rxjava2:$paging_version") // optional - RxJava3 support implementation("androidx.paging:paging-rxjava3:$paging_version") // optional - Guava ListenableFuture support implementation("androidx.paging:paging-guava:$paging_version") // optional - Jetpack Compose integration implementation("androidx.paging:paging-compose:3.3.2") }
라이브러리 아키텍처
Paging 라이브러리의 구성요소는 앱의 세 가지 레이어에서 작동합니다.
- 저장소 레이어
ViewModel
레이어- UI 레이어
이 섹션에서는 각 레이어에서 작동하는 페이징 라이브러리 구성요소와 이 구성요소가 함께 작동하여 페이징된 데이터를 로드하고 표시하는 방법을 설명합니다.
저장소 레이어
저장소 레이어의 기본 페이징 라이브러리 구성요소는 PagingSource
입니다. 각 PagingSource
객체는 데이터 소스와 이 소스에서 데이터를 검색하는 방법을 정의합니다. PagingSource
객체는 네트워크 소스 및 로컬 데이터베이스를 포함한 단일 소스에서 데이터를 로드할 수 있습니다.
사용할 수 있는 다른 페이징 라이브러리 구성요소는 RemoteMediator
입니다. RemoteMediator
객체는 로컬 데이터베이스 캐시가 있는 네트워크 데이터 소스와 같은 계층화된 데이터 소스의 페이징을 처리합니다.
ViewModel 레이어
Pager
구성요소는 PagingSource
객체 및 PagingConfig
구성 객체를 바탕으로 반응형 스트림에 노출되는 PagingData
인스턴스를 구성하기 위한 공개 API를 제공합니다.
ViewModel
레이어를 UI에 연결하는 구성요소는 PagingData
입니다. PagingData
객체는 페이지로 나눈 데이터의 스냅샷을 보유하는 컨테이너입니다. PagingSource
객체를 쿼리하여 결과를 저장합니다.
UI 레이어
UI 레이어의 기본 페이징 라이브러리 구성요소는 페이지로 나눈 데이터를 처리하는 RecyclerView
어댑터인 PagingDataAdapter
입니다.
또는 포함된 AsyncPagingDataDiffer
구성요소를 사용하여 고유한 맞춤 어댑터를 빌드할 수 있습니다.
추가 리소스
Paging 라이브러리에 관한 자세한 내용은 다음과 같은 추가 리소스를 참고하세요.
Codelab
샘플
추천 서비스
- 참고: JavaScript가 사용 중지되어 있으면 링크 텍스트가 표시됩니다.
- 페이징 데이터 로드 및 표시
- Paging 3으로 이전
- 네트워크 및 데이터베이스의 페이지