일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 넷플릭스
- Linux
- Coroutine
- androidx
- Streaming
- 1인개발자
- recyclerview
- Freesound
- 파이썬
- Flutter
- bash
- 이모지
- Firebase
- 벤자민플랭클린
- 소울칼리버6
- kotlin
- 오픈소스
- jetpack compose
- ASMR
- 공부집중
- 명심보감
- DART
- 공자명언
- 장자명언
- 좋은글필사하기
- 이모지메모
- FSM
- 명언모음
- 코틀린
- Android
Archives
- Today
- Total
Vintage appMaker의 Tech Blog
[Flutter tip] Flutter key 사용 - Quick summary 본문
Source code or Tip/Flutter & Dart
[Flutter tip] Flutter key 사용 - Quick summary
VintageappMaker 2022. 8. 5. 16:04
Flutter에서 key를 사용하는 이유
1. 한 화면에 여러개의 같은 형의 Widget을 관리하지 않는다면 쓸 이유는 거의 없다(Globalkey 예외)
2. 여러개의 Widget을 1회 생성이후, 추가/삭제/이동을 할 경우에 반드시 필요하게 된다(stateful).
3. Flutter가 선언형 프로그래밍이라 절차형(객체의 이름을 명명하여 메소스 사용)방법처럼 처리가 힘들기에, 화면위젯과 state 위젯의 매치가 초기배열 순서대로 되어 있다. 그렇기에 재배열 시, Flutter에서는 키값으로 다시 매칭해주지 않으면 Widget과 state가 잘못매칭되는 경우가 발생한다.
4. ValueKey, ObjectKey, UniqueKey, PageStorageKey, GlobalKey가 있다.
- UniqueKey: 유니크한 이름값 생성하여 배열처리. 많이 사용됨. build 함수 내에서 구현하지 않는 것이 좋음.
- ValueKey: 키값에 이름을 정의하여 생성. 예제로 TextField를 많이 사용함.
- ObjectKey: 객체로 관리할 필요가 있을 때 사용.
- PageStorageKey: 스크롤뷰에서 최종 움직인 위치를 저장하고자 할 때 사용.
- GlobalKey: 다른위젯에서 key값을 받은 위젯의 상태를 액세스할 때 사용(다른위젯 상태를 액세스하려먼 가장 편하게 사용할 수 있는 방법임).
🍕GlobalKey 사용법
🍕UniqueKey 사용법
🍕PageStorageKey 사용법
🍕ValueKey 사용법
🍕ObjectKey 사용법
'Source code or Tip > Flutter & Dart' 카테고리의 다른 글
[dart] dart에서 list 항목 비교하여 새로운 list 만들기 (0) | 2022.08.08 |
---|---|
[github] Flutter ASMR Timer 소스 (0) | 2022.08.06 |
[flutter] listView(Column)안에 list, Grid, pageView 넣기 (0) | 2022.08.04 |
[Flutter] BackdropFilter를 이용한 Blur (0) | 2022.07.31 |
[Flutter] Transform.translate를 이용한 좌표이동 - 영역침범하기 (0) | 2022.07.28 |
Comments