Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 최댓값 최솟값
- navigation component
- suspend programming
- 개발하는 정대리
- 성빈랜드
- Activirty
- 피보나치 수 2
- capitalize
- 브론즈 1
- kotlin
- 백준
- github action
- .github
- gradlew
- 2레벨
- 실버 4
- Myungpyo Shim
- 브론즈1
- 데이터베이스
- DB
- Bitrise
- LazyRow
- keystore
- DB 기능
- 프로그래머스
- 실버2
- LazyColumn
- Android
- 데이터베이스 첫걸음
- compose
Archives
- Today
- Total
plzy의 개발 블로그
[Compose] compose에서 RecyclerView를 쓰는법 본문
기존에 list 뷰를 만들려면 RecyclerView.Adapter, RecyclerView.ViewHolder 등을 만들어야 했다.
무척 번거로웠지만 compose에서는 어떻게 만들면 될까?
LazyColumn
LazyColumn이란 compose에서 list를 만들 때 쓰는 layout이다.
이름부터 볼 수 있듯이 세로형 list를 만들 수 있는 것인데
한번 코드를 살펴보자.
@Composable
fun Greetings(name: List<String> = List(1000) { "${it}" }) {
LazyColumn(Modifier.padding(vertical = 4.dp)) {
items(name) { name ->
Greeting(name = name)
}
}
}
items에 어떠한 데이터가 들어갈지 넣어주면 된다.
결과로 이런 layout이 그려질 것이다.
LazyRow
LazyRow는 LazyColumn과 같이 list 뷰를 그려줄 때 사용한다.
이름에서 볼 수 있듯이 가로형 list의 뷰를 그릴 때 사용한다.
한번 코드를 살펴보자
@Composable
@Preview
fun Greetings(name: List<String> = List(1000) { "${it}" }) {
LazyRow(Modifier.padding(vertical = 4.dp)) {
items(name) { name ->
Greeting(name = name)
}
}
}
코드는 크게 달라진 것은 없고
LazyColumn에서 LazyRow로 바뀌었을 뿐이다.
기존에는 번거롭게 리스트 뷰를 만들어야 했지만 Compose에서는 간단하게 만들 수 있어 큰 이점이다.
상태유지
만약 화면을 회전하면 기존 layout의 변화가 초기화될 것이다.
이를 방지할려면 remember 대신 rememberSaveable을 사용하면 된다.
'Android' 카테고리의 다른 글
LiveData 대신 Flow가 나온 이유? (0) | 2022.06.22 |
---|---|
[Android] 코루틴이란 무엇인가. (0) | 2022.05.17 |
[Android] paging 라이브러리 어떻게 사용할까? (0) | 2022.05.06 |
flow에 대해 알아보자 #1. flow 개념알기 (0) | 2022.05.06 |
[Android] github action으로 CI 구축하기 (0) | 2022.03.31 |