Search

Firestore 사용법 정리 with Flutter

부제
Flutter 에서 Firestore 을 사용 예 아카이브
카테고리
테크
세부 카테고리
Flutter
Combine 카테고리
최종편집일
2023/08/28 04:42
작성중
관련된 포스팅
생성 일시
2023/08/18 11:53
태그
Firestore

1. 한번 가져오기

1-1 커스텀 객체로 불러오기

1-2 리스트로 된 커스텀 객체로 불러오기

1.
Future<List<커스텀클래스>> 를 리턴하는 async 함수 정의
2.
위젯에서 해당 메서드 호출하기
a.
initState() {} 에서 위젯 초기화와 함께 호출 및 데이터 세팅
b.
setState() 와 함께 호출하기

2. 리스너 만들기

2-1.

1.
static 메서드로 Stream<QuerySnapshot<Map<String, dynamic>>> 를 리턴하는 함수를 만들어준다.
class FirestoreService { static Stream<QuerySnapshot<Map<String, dynamic>>> getStream() { print("DEBUG: stream Entries"); return entryDB .orderBy('enrolledAt') .where("eventID", isEqualTo: "123456") .snapshots(); } }
Dart
복사
2.
위에서 만든 Stream 타입을 리턴하는 함수를 StreamBuilder 위젯을 만드는 과정에서 호출해준다.
StreamBuilder<QuerySnapshot>( stream: FirestoreService.getStream(), builder: (context, snapshot) { if (snapshot.hasError) { print("ERROR: ${snapshot.error}"); return Center( child: Text('불러올 수 없습니다.'), ); } if (snapshot.connectionState == ConnectionState.waiting) { return Center( child: CircularProgressIndicator(color: Colors.black), ); } List<DocumentSnapshot> documents = snapshot.data!.docs; return ... ); })),
Dart
복사