Riverpod Provider 종류(Different Types of Providers)
Provider의 종류
- Provider
- StateProvider
- StateNotifierProvider
- FutureProvider
- StreamProvier
- ChangeNotifierProvider (사용 안함 - Provider 마이그레이션 용도)
- 각각 다른 타입을 반환해주고 사용 목적이 다르다.
- 모든 Provider는 글로벌하게 선언된다.
사실상 기능은 거이다 똑같고 상태를 데이터를 관리하고 거기서 데이터를 어떻게 관리하냐 차이임
Provider
- 가장 기본 베이스가 되는 Provider
- 아무 타입이나 반환 가능
- Service, 계산한 값등을 반환할 때 사용
- 반환값을 캐싱할 때 유용하기 사용된다.
- 여러 Provider의 값들을 묶어서 한번에 반환값을 만들어낼 수 있다.
StateProvider
- UI에서 “직접적으로” 데이터를 변경할 수 있도록 하고싶을 때 사용
- 단순한 형태의 데이터만 관리 (int , double , String 등)
- Map , List 등 복잡한 형태의 데이터는 다루지 않음
- 복잡한 로직이 필요한 경우 사용하지 않음
- number++ 정도의 간단한 로직으로만 한정 (값을 바꾸고 싶으면 꼭 .notifier를 붙여줘야한다.)
StateNotifierProvider
- StateProvider와 마찬가지로 UI에서 “직접적으로” 데이터를 변경할 수 있도록 하고싶을 때 사용
- 복잡한 형태의 데이터 관리가능 (클래스의 메소드를 이용한 상태관리)
- StateNotifier를 상속한 클래스 반환
FutureProvider (그렇게 유용한 Provider는 아님)
- Future 타입만 반환가능
- API 요청의 결과를 반환할 때 자주 사용
- 복잡한 로직 또는 사용자의 특정 행동뒤에 Future를 재실행하는 기능이 없음
- 필요할 경우 StateNotifierProvider 사용
StreamProvider
- Stream 타입만 반환가능
- API 요청의 결과를 Stream으로 반환할 때 자주 사용
비교차트
ref.read vs ref.watch
- ref.watch는 반환값이 업데이트가 있을 때 지속적으로 build 함수를 다시 실행해준다.
- ref.watch는 필수적으로 UI관련 코드에만 사용한다.
- ref.read는 실행되는 순간 단 한번만 provider값을 가져온다.
- ref.read는 onPressed 콜백처럼 특정 액션 뒤에 실행되는 함수 내부에서 사용된다.