CH02 Provider Overview



necessity of provider




Widget A ์์ counter ๋ผ๋ ๋ฐ์ดํฐ์ increment ๋ผ๋ ํจ์๊ฐ ํ์ํ ์ํฉ์ด๊ณ , Widget B ์์๋ counter ๋ผ๋ ๋ฐ์ดํฐ๋ง ํ์ํ ์ํฉ.
Widget A, Widget B ๋ชจ๋์์ ๋์ผํ ๋ฐ์ดํฐ์ธ counter ๊ฐ ํ์ํ๋ฏ๋ก ๊ณตํต๋ ๋ถ๋ชจ Widget C ์์ ์ ์.
counter ์ increment ์ ๊ฒฝ์ฐ Widget C ์์ ์ ์ธํ์ง๋ง ์ ์ ์ ์ด๋ Widget A ์์ ํ๋ฏ๋ก Inversion of control ๋ฐ์.
Widget B ์ counter ๋ฅผ ๋๊ฒจ์ฃผ๊ธฐ ์ํด์ Widget C ์ Widget B ์ฌ์ด์ Widget ์ด ํ์ํ์ง๋ ์์ counter ๋ผ๋ ๋ฐ์ดํฐ๋ฅผ ๊ฐ๊ฒ ๋จ.
managing state without provider

Counter B ๋ง ๋ด์๋ ์ด๋์ rebuilding ์ด ๋ฐ์ํ๋์ง ์ถ์ ํ๊ธฐ๊ฐ ์ฝ์ง ์๋ค.
๊ณตํต ์๋จ ๋ถ๋ชจ Widget ์์ setState() ํธ์ถ๋๋ฏ๋ก ์ธ๋ฐ์์ด ๋ ๋ง์ Widget ์ด rebuild ๋์์ด ๋์ด ํผํฌ๋จผ์ค๊ฐ ๋จ์ด์ง ์ ์๋ค.


๊ฒฐ๊ตญ StateManagement ๋ ์๋ ๋ ๊ฐ์ง ํ์๊ฐ ํต์ฌ์ด๋ค.
Dependency Injection (Object๋ฅผ Widget Tree ์์์ ์ฝ๊ฒ ์ ๊ทผํ ์ ์๋๋ก ํ๋ค.)
Synchronizing data and UI


Provider ๋ Widget ์ Widget ์ด ์๋ ๋ฐ์ดํฐ์ method ์ ์ฝ๊ฒ ์ ๊ทผํ ์ ์๋ ๋ฐฉ๋ฒ์ ์ ๊ณตํ๋ค.
๋ฐ์ดํฐ๊ฐ ๋ณ๊ฒฝ ๋์์ ๋ ๋ฐ์ดํฐ๊ฐ ๋ณ๊ฒฝ๋์๋ค๋ ์ฌ์ค์ ๊ทธ ๋ฐ์ดํฐ๊ฐ ํ์ํ Widget ์ ์ ๊ณตํด์ ํ์์ rebuild ๋ ์ ์๋๋ก ํ๋ค.
๊ฒฐ๊ตญ ๋น์ฆ๋์ค ๋ก์ง๊ณผ ํ๋ฉด์ด ๋ถ๋ฆฌ ๋๋ ๊ฒ์ด๋ค.
dependency injection using provider

์ฃผ๋ชฉํด์ผํ ํฌ์ธํธ๋ ์๋ ๋ ๊ฐ์ง์ด๋ค.
Widget Tree ์์์ class Dog ๋ก์ ์ ๊ทผ์ด ์ผ๋ง๋ ์ฝ๊ฒ ๊ฐ๋ฅํ์ง
์ด ๋ฐฉ์์ด ์์ฑ์๋ก ๋ฐ์ดํฐ๋ฅผ ๋๊ฒจ์ฃผ๋ ๊ฒ๋ณด๋ค ์ผ๋ง๋ ๋ ๊ฐํธํ์ง

Provider ์ญ์ Widget ์ด๋ค.
create ํ๋กํผํฐ์์ Widget ์ด ํ์๋ก ํ๋ dog ์ธ์คํด์ค๋ฅผ ๋ง๋ ๋ค.
create ์ assign ๋๋ ํจ์๊ฐ return ํ๋ object ์ Provider ํ์ Widget ๋ค์ ์ ๊ทผ์ด ๊ฐ๋ฅํ๋ค.
Provider ์ static ํจ์์ธ of ๋ฅผ ์ด์ฉํ๋ฉด Widget Tree ๋ฅผ ์๋ก traverse ํ๋ฉด์ ์ํ๋ Type ์ ์ธ์คํด์ค๋ฅผ ์ฐพ์ ์ ์๋ค.
Provider.of<Dog>(context)์ ๊ฐ์ ์์ธ๋ฐ, ์ฌ๊ธฐ์ context ๋ฅผ ์ฃผ๋ ์ด์ ๋ context ๋ฅผ ์ด์ฉํด์ Widget Tree ๋ฅผ ์๋ก ํ์ํ๊ธฐ ๋๋ฌธ์ด๋ค.

<T>๊ฐ ๊ฐ์ ๋ ๊ฐ ์ด์์ ์ธ์คํด์ค๊ฐ ์๋ ๊ฒฝ์ฐ์๋ ๊ฐ์ฅ ๊ฐ๊น์ด ์ธ์คํด์ค๋ฅผ ๊ฐ์ ธ์จ๋ค.
ChangeNotifier & addListener


addListener ๋ ์๋์ผ๋ก dispose ๋์ง ์๊ธฐ ๋๋ฌธ์ ์๋์ผ๋ก ์ง์ dispose ์์ผ์ค์ผํ๋ค.
์ฝ๋ ๋ด Provider ์ ๊ฑฐ ํ ChangeNotifier ์ addListener ๋ฅผ ๊ฐ์ด ์ฐ๋ฉด์ Listener ๊ฐ ์๋ํ๋ ๊ฒ์ ๋ณด๊ณ , ๋ถํธํ ์ ์ ์ดํด๋ณด์๋ค.(Provider ์ญ์ ํ ์์ฑ์๋ก ๋ฐ์ดํฐ๋ฅผ ๋๊ฒจ์ฃผ์๋ค.)
ChangeNotifierProvider


Provider.of<T>(context)๋ก ์ธ์คํด์ค๋ฅผ ํ์ & ์ ๊ทผ์ ํด๋น ๋ฐ์ดํฐ์ ๋ณ๊ฒฝ์ listen ํด์ผํ ์ง์ ํ์์ฑ(๋ฐ์ดํฐ ๋ณ๊ฒฝ์ ๋ฐ๋ฅธ UI rebuild)์ด ์์๋์ ์์๋ ๊ฐ๊ฐ ์ต์ ๊ฐ์ด ๋ค๋ฆ์ ์ธ์งํ๋ค.Provider.of<Dog>(context).ageProvider.of<Dog>(context, listen: false).age
๊ฒฐ๋ก ์ ์ผ๋ก ์๋์ ๊ฐ๋ค. ๊ฒฐ๊ตญ ์๋ ๋ ๊ฐ์ง๊ฐ State Management ์ด๋ค.
ChangeNotifierProvider ๋ ๋ฐ์ดํฐ๋ฅผ ํ์๋ก ํ๋ Widget ์ด dependency injection ์ ๋ฐ์์ผ๋ก์จ ๋ฐ์ดํฐ(์ธ์คํด์ค)์ ์ฝ๊ฒ ์ ๊ทผํ ์ ์๊ฒ ํด์ค๋ค.
๋ฐ์ดํฐ์ ๋ณ๊ฒฝ์ด ๋ฐ์ํ์ ๋ ์ด ๋ฐ์ดํฐ์ ๋ณํ์ ๋ง์ถฐ์ ์ ํ์ ์ผ๋ก Widget ์ rebuild ํ ์ ์๊ฒ ํด์ค๋ค.
ChangeNotifier ์ notifyListeners() ๋ ์ด๋ฅผ ๊ตฌ๋ ํ๊ณ ์๋ ๋ชจ๋ listener ๋ค์๊ฒ ๋ณ๊ฒฝ ์ฌ์ค์ ์๋ฆฌ๊ณ rebuild ํ๋๋ก ๋ง๋ ๋ค. ๊ณต์๋ฌธ์๋ฅผ ์ฐธ๊ณ ํ์.
read, watch, select extension methods

4.1 ๋ถํฐ Provider ๋ฅผ ๋ ๊ฐํธํ๊ฒ ์ธ ์ ์๊ฒ ํด์ฃผ๋ extension ์ด ๋์ ๋จ.
์ผ์ข ์ shortCut ์ด๋ผ๊ณ ๋ณด๋ฉด ๋๊ณ , ๊ทธ๋ฅ ์ฐ์ง ๋ง๊ณ ์ํ๋ค์ด ๋ญ์ง ์ดํดํ๊ณ ์๋๊ฒ ์ค์ํ๋ค.
context.select๋ ๋ค์์ property ๋ฅผ ๊ฐ์ง๊ณ ์๋ object ์ ํน์ property ์ ๋ณํ๋ง listen ํ๊ณ ์ถ์ ๋ ์ฌ์ฉํ๋ค.context.watch๋ ํน์ property ํ๋๋ง ๋ฐ๋์ด๋ rebuild ๋ฅผ ํ๋ ๊ฒ์ ๋ฐํดcontext.select๋ listen ํ๊ณ ์ถ์ ๊ฒ๋ง ์ ๋ณ์ ์ผ๋ก listen ์ด ๊ฐ๋ฅํ๋ค.(ํผํฌ๋จผ์ค ๊ณ ๋ ค ์ธก๋ฉด์์ ์ฌ์ฉํ ์ ์๋ค.)
context.watch vs context.select
Multiple Provider

ํ๋์ Provider ๋ฅผ ์ฌ์ฉํ๋๋ผ๋ MultiProvider ๋ฅผ ์ฌ์ฉํด๋์ผ๋ฉด ํ์ฅ์ฑ์ด ์๋ค.
Future Provider

๊ฐ์ฌ๋์ ๊ฐ์ธ์ ์ผ๋ก ์ธ ์ผ์ด ๊ฑฐ์ ์์๋ค๊ณ ํจ.
๋ง์ฝ ์ธ ์ผ์ด ์์ผ๋ฉด FutureBuilder ๋ฅผ ์ธ ๊ฒ ๊ฐ๋ค๊ณ ํจ.
Widget Tree ์๋ ๋น๋๊ฐ ๋์๋๋ฐ ์ฌ์ฉํ๊ณ ์ ํ๋ ๊ฐ์ด ์์ง ์ค๋น๊ฐ ๋์ง ์์์๋ ์ฌ์ฉํ๋ค.
Future ๊ฐ resolve ๋์ง ์์์๋, initialData ๋ก build ํ๊ณ Future ๊ฐ resolve ๋๋ฉด rebuild ๋๋ค. ์ด 2๋ฒ build ๊ฐ ๋๋ค๋ ๊ฒ. (๋ง์ฝ ์ฌ๋ฌ๋ฒ build ๋ฅผ ์ํ๋ค๋ฉด StreamProvider ์ฌ์ฉํ๋ค.)
์ ์ฌํ ๋ด๋ฌ์ผํ ๋ถ๋ถ์ FutureProvider ์ ๋์์ Future ์ด๊ธฐ๋ง ํ๋ฉด ๋๋ ๊ฒ์ด๋ผ๋ ๊ฒ์ด๋ค. ์ฆ, ์ธ์คํด์ค ๋ด์ ์ ์๋ method ๋ฅผ ๋์์ผ๋ก ํ๊ณ ์ถ๋ค๋ฉด ์ธ์คํด์ค ์ ์ฒด๋ฅผ return ํ ํ์๊ฐ ์๊ณ ํน์ ๋ฉ์๋๋ง ์ ๊ณตํ๋ ํํ๋ก ์ฌ์ฉํด์ผ ํ๋ค.
FutureProvider ๋ด์์ context.read ์ฌ์ฉ์ด ๊ฐ๋ฅํ๋ค. ์ด์ ๋ ์์์ ChangeNotifierProvider ๊ฐ FutureProvider ๋ณด๋ค ์์ Widget ์ผ๋ก ์ด๋ฏธ ์ฌ์ฉ๋์๊ธฐ ๋๋ฌธ์ด๋ค.
StreamProvider

๊ฐ์ฌ๋ ๊ฐ์ธ์ ์ผ๋ก๋ FutureProvider ๋ณด๋ค StreamProvider ๋ฅผ ์ฌ์ฉํ ์ผ์ด ๋ ๋ง์๋ค๊ณ ํจ.
์ฐ์๋๋ Future value ๋ฅผ ํ๊ฒ์ผ๋ก ํ๋ Provider
create ๋ ํ ๋ฒ๋ง called ๋๊ธฐ ๋๋ฌธ์ watch ๋ฅผ ์ฌ์ฉํ๋ฉด ์๋ฌ๊ฐ ๋ฐ์ํ๋ค. ๋ ผ๋ฆฌ์ ์ผ๋ก๋ read ๊ฐ ๋ง๋ค.
async ์ async* ์ ์ฐจ์ด๋ ์ฌ๊ธฐ๋ฅผ ์ฐธ๊ณ ํ๋ค. ๊ฐ๋ตํ ์ค๋ช ํ๋ฉด return ํ์ ์ด
Stream<T>๋ฅผ ์์ฐํ๋ฉด(+ method ๋ฅผ ๋ ๋์ง ์์ผ๋ฉด์) async* ๋ฅผ ์ฌ์ฉํ๋ค.์ด๋ฐ ๊ฒฝ์ฐ return ์ ์ฌ์ฉํ์ง ์๋๋ค. method ๋ฅผ ๋ ๋์ง ์๊ธฐ ๋๋ฌธ์ ์ข ๊ฒฐ์ฒ๋ฆฌ ํ๋ฉด ์๋๋ค. yield ๋ฅผ ์ฌ์ฉํ๋ฉฐ, yield ์ ์ฌ์ ์ ์๋ฏธ๋ โ์์ฐํ๋คโ ๋ผ๋ ๋ป์ด๋ค.
Consumer


Consumer ์ ํ๋ผ๋ฏธํฐ (BuildContext context, Dog dog, Widget? child) ์ค child ๋ builder ๋ด์์ rebuild ๋ ํ์๊ฐ ์๋ Widget ์ด ์๋ ๊ฒฝ์ฐ๋ฅผ ๋๋นํด์ ์์ ๊ฐ์ด ์ฌ์ฉํ๋ค. ์ ์์ ์์๋ ์ด๋ค ๊ฒฝ์ฐ๋ rebuild ๋ ํ์๊ฐ ์๋ Text Widget ์ child ๋ก ๋นผ์ฃผ์๋ค.
์ดํด๊ฐ ์๊ฐ๋ฉด ์ ํฌ๋ธ์ ๋จ์์๋ ๊ฐ์ ์์ ์ด ๋ถ๋ถ์ ๋ค์ ๋ณด๊ณ ์ค์.
Consumer, builder, ProviderNotFoundException






Consumer ๋ฅผ ์ฐ๋ builder ๋ฅผ ์ฐ๋ ๋ ์ค ํธํ ๋ฐฉ๋ฒ์ ์ฌ์ฉํ์.
Selector

Consumer ์ ์ ์ฌํ๋ฐ Consumer ๋ณด๋ค ๋ ์ธ์ธํ ์ปจํธ๋กค์ ๊ฐ๋ฅํ๊ฒ ํด์ค๋ค.
์์์ ํ์ตํ
context.select<T, R>((R selector(T value))) => R๊ณผ ์ ์ฌํ ๊ฐ๋ ์ด๋ค.์ง๊ธ ํ์ตํ Selector ๋ผ๋ Widget ๊ณผ
context.select<T, R>((R selector(T value))) => R๋ ๊ณตํต์ ์ผ๋ก ํน์ property ์ ๋ณ๊ฒฝ์ ๋ํด์ react ํ ์ ์๋๋ก ํ๋ ๊ฒ.
ProviderNotFoundException ๋ ์์๋ณด๊ธฐ, Builder Widget

extension ์ context ๋ build method ์ buildContext ์์ ๋ช ์ฌ. ๊ทธ๋์ ๊ทธ๊ฑธ ๊ทธ๋๋ก ์ฌ์ฉํ๋ฉด ProviderNotFoundException ๊ฐ ๋ฐ์ํ ์ ๋ฐ์ ์๋ค.
์ด๋ฅผ ํด๊ฒฐํ๋ ค๋ฉด โConsumer, builder, ProviderNotFoundExceptionโ ์์ ํ์ตํ builder ํ๋กํผํฐ๋ฅผ ์ฌ์ฉํ๊ฑฐ๋ child ๋ก Widget ์ ๋ฐ๋ก ๋นผ์ ๋ณ๋์ Widget ์ผ๋ก ์ฌ์ฉํ๋ค.
Builder Widget ์ context ๋ ์กฐ์ Widget ์ BuildContext ๊ฐ ์๋๊ณ Builder Widget ์์ฒด์ BuildContext ์ด๊ธฐ ๋๋ฌธ์ ์ด๋ฅผ ์ฌ์ฉํด์ Widget Tree ๋ฅผ ์๋ก ํ์ํ๋ฉด ์ํ๋ T(type)์ ๋ํ Provider ๋ฅผ ์ฐพ์ ์ ์๋ค.
builder ํ๋กํผํฐ๋ ์ด๋ฏธ ํ์ตํ ๋ฐ์ ๊ฐ์ด syntax sugar ๋ก Builder Widget ์ด ์ฌ์ฉ๋ ๊ฒ๊ณผ ๋์ผํ๋ค.
Provider Access - Anonymous route access




Consumer, builder, ProviderNotFoundException์์ Error Message 2 ์ ๊ฒฝ์ฐ๋ฅผ ํ์ตํจ.Consumer, builder, ProviderNotFoundException์์ Error Message 3 ์ ๊ฒฝ์ฐ parent-child ๊ด๊ณ์์ child ๋ก์ Widget Tree ๋ฅผ ์๋ก ํ์ํ๋ฉด์ Provider ๋ฅผ ์ฐพ์ํ๋๋ฐ ํ์์ ์ฌ์ฉํ๋ context ๊ฐ ํด๋น child ์ context ๊ฐ ์๋๋ผ, Provider ์์น์ ๊ฐ๊ฑฐ๋ ํน์ ๊ทธ ์ด์์ level ์ context ์ผ ๊ฒฝ์ฐ ๋ฐ์ํ ์๋ฌ.Error Message 2 ๋ parent-child ๊ด๊ณ์์ child ๋ก์ ์๋ก ํ์์ด ๋ฐ์๋์ด์ผ ํ๋๋ฐ, ๋ค๋ฅธ route ์์ ํ์ํ์ผ๋ฏ๋ก(์ฌ๊ธฐ์ ์์ ๋ sibling ๊ด๊ณ) ๋ชป์ฐพ๋ ๋ฌธ์ ๊ฐ ๋ฐ์.
์ด ๋์ ํด๊ฒฐ ๋ฐฉ๋ฒ์ value constructor ์ด๋ค. ์๋ก์ด sub-tree ์ ์ด๋ฏธ ์กด์ฌํ๋ class ์ ๋ํ access ๋ฅผ ์ ๊ณตํ ๋ ์ฌ์ฉ. value constructor ๋ class ๋ฅผ ์๋์ผ๋ก close ํ์ง ์๋๋ค.
context.read ์ ์ฌ์ฉํ๋ context ๋ Navigator.push ์ context ๋ฅผ ์ฌ์ฉํด์ผ ํ๋ค. MaterialPageRoute ์ context ๊ฐ ์๋์ ๋ช ์ฌ. ์๋ก ํ์ํ์ฌ Provider ๋ฅผ ์ฐพ์์ผ ํ๋๋ฐ, MaterialPageRoute ์ ๊ฒฝ์ฐ sibling ์ด๊ธฐ ๋๋ฌธ์ MaterialPageRoute ์ context ๋ฅผ ์ฌ์ฉํ ๊ฒฝ์ฐ Provider ๋ฅผ ์ฌ์ ํ ๋ชป์ฐพ๋๋ค.
์๋๋ ์ฝ๋ ์ ์ฒด.
Provider Access - Named route access
๊ณ์ํด์ Provider Access ์ ๋ํด์ ํ์ตํ๋ค. ๋ฐ๋ก ์์์๋ Anonymous route access ๋ฅผ ์ดํด๋ณด์๋ค. ์ ์์ ์ผ์ด์ค๊ฐ Anonymous route ๋๋ฉด Navigator.push ๋ฅผ ์ฌ์ฉํ๊ธฐ ๋๋ฌธ์ด๋ค.
์ด๋ฒ์๋ Named route ์์์ Provider ์ ๋ํ access ๋ฅผ ํ์ตํ๋ค.
๋ณต์ต ์ฐจ์์์ ์ง๊ณ ๋์ด๊ฐ์๋ฉด, Anonymous route ๊ฐ Anonymous ์ธ ์ด์ ๋ ๋ง ๊ทธ๋๋ก ์ด๋ฆ์ด ์์ด์๋ค. ๋ฐ๋๋ก ์ด๋ฆ์ด ์๋ค๋ ๋ง์ MaterialApp ์์ routes property ๋ด์ route ์ฃผ์์ Screen ์ผ๋ก ์ฌ์ฉํ Widget ์ด ๋ฑ๋ก๋์ด ์๋ค๋ ๊ฒ์ ์๋ฏธํ๋ค. ๋ฐ๋ก ์ Anonymous route ๋ Navigator.push ๋ก route ์ค์ ์ ๋ฐ๋ก ํด์ฃผ์ง ์๊ณ ํ๋ฉด Stack ์ ๋ฐ๋ก ์์ ์ฌ๋ฆฐ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ Anonymous ์๋ค.
์์ ๊ฐ์ด routes ์ค์ ๋ถ๋ถ์์ ChangeNotifierProvider.value ๋ก ๊ฐ์ธ์ฃผ๋ฉด ๋๋๋ฐ, ์ฃผ์ํ ์ ์ด ์๋ค. create ๋ฅผ ์ฌ์ฉํด์ ์ฌ์ฉํ ์ธ์คํด์ค๋ฅผ ์์ฑํ ๊ฒฝ์ฐ ์๋์ผ๋ก dispose ๋ฅผ ํด์ฃผ๋๋ฐ ์ง๊ธ ์์ ๊ฒฝ์ฐ create ๋ก ์ธ์คํด์ค๋ฅผ ์์ฑํ์ง ์์๊ณ , ์๋ ์ ์ฒด ์ฝ๋์ ๋์์๋ค์ํผ state ์์ ์ธ์คํด์ค๋ฅผ ์ง์ ์์ฑํด์คฌ๋ค.
๋ฐ๋ผ์ dispose ์ญ์ ์๋์ ๊ฐ์ด ์ง์ ํด์ค์ผํ๋ค.
์๋๋ ์ ์ฒด ์ฝ๋์ด๋ค.
Provider Access - Generated route access, Global access
ํ์ตํ Provider Access ์ ๋ํด์ ๋ฌด์์ ํ๊ณ , ๋ฌด์์ด ๋จ์๋์ง ๋ค์ ์ง์ด๋ณธ๋ค.
Provider Access
Anonymous route access Navigator.push ๋ด์์ ์ฌ์ฉํ screen ์ value constructor ๋ก ๊ฐ์ธ์ฃผ๋, context ๋ฅผ Navigator.push ์ ๊ฒ์ ์ฌ์ฉํ๋ค.
Named route access routes ์ค์ ๋ถ๋ถ์์ value constructor ๋ก ๊ฐ์ธ์ฃผ๋, ์ฌ์ฉํ ์ธ์คํด์ค๊ฐ create ๋ก ๋ง๋ค์ด์ง๊ฒ ์๋๋ผ ์๋์ผ๋ก dispose ๋์ง ์์ผ๋ฏ๋ก ์ง์ ํด๋น ์ธ์คํด์ค๋ฅผ dispose ์ฒ๋ฆฌ ํด์ค๋ค.
Generated route access Named route access ๊ณผ ๊ฑฐ์ ๋์ผํ๋ค. ์๋ ์ฝ๋๋ฅผ ๋ณด์.
Global access ์ ๊ฒฝ์ฐ ์๋์ ๊ฐ์ด ์ต ์๋จ์ Provider ๋ก ๊ฐ์ธ๋๋ฉด ์ ๊ทผ์ด ๊ฐ๋ฅํ๋ค.
ํ์ง๋ง ๋ถ์ ํ๊ฒฝ ๋ฐ ์ ์ง๋ณด์ ๋ฑ์ ๊ณ ๋ คํ ๋ ์ ์ ์ง ๋ชปํ ๋ฐฉ์์ด๋ค. ์ค๋ฌด์์ ์ด๋ ๊ฒ ์ฌ์ฉํ ์ธ์คํด์ค๊ฐ ์์๊น ์ถ๋ค. ์ ์ ๋ก๋ฉ์คํผ๋๋ฅผ ์ด๋ ๊ฒ global access ๊ฐ๋ฅํ๊ฒ ์ฒ๋ฆฌํด์ ์ฌ์ฉํ๋ ๊ฒ ๊ฐ๊ธฐ๋ ํ๊ณ .. ์คํ์์ค ํ๋ก์ ํธ๋ค์ ํ๊ตฌํ ๋ ํ์ธํด๋ณด๋๋ก ํ์.
ProxyProvider - ๊ฐ์ 1

Provider ์์ ๋ค๋ฅธ Provider ์ ๊ฐ์ด ํ์ํ ๊ฒฝ์ฐ์ ProxyProvider ๋ฅผ ์ฌ์ฉํ๋ค.
๋ค๋ฅธ Provider ์ ๊ธฐ๋ฐํ์ฌ value ๋ฅผ ๋ง๋๋ Provider (A provider that builds a value based on other provider)
๋ค๋ฅธ Provider ์ ๊ฐ์ ์์กดํด์ value ๋ฅผ ๋ง๋๋ Provider ์ธ ๊ฒ์ด๋ค.
๊ผญ ๋ค๋ฅธ Provider ์ ์์กดํ์ง ์๋๋ผ๋, ์ด๋ค ๋ณํ๋ ๊ฐ์ ์์กดํด์ผ ํ๋ค๋ฉด ProxyProvider ๋ฅผ ์ฌ์ฉํ๋ค.

ProxyProvider ๋ ์ข ๋ฅ๊ฐ ๋ง๋ค.


create ๋ optional ์ด๊ณ update ๊ฐ required ์ด๋ค.
ProxyProvider ๊ฐ ์์ฒด์ ์ผ๋ก ๋ง๋ค๊ณ ๊ด๋ฆฌํด์ผํ value ๊ฐ ์๋ค๋ฉด create ๊ฐ ํ์ํ์ง๋ง, ๊ทธ๋ฐ ๊ฒฝ์ฐ๊ฐ ์๋๋ผ๋ฉด ๋ง๋ค ํ์๊ฐ ์๊ธฐ ๋๋ฌธ์ด๋ค.
๊ทธ๋์ create ๋ ํ ๋ฒ๋ง called, ๋๊ณ update ๋ ์ฌ๋ฌ๋ฒ called ๋๋ค.
ProxyProvider ๋ ๋ค๋ฅธ Provider ๊ฐ ์ ๊ณตํ๋ ๊ฐ์ ์์กดํ๋๋ฐ, ๋ค๋ฅธ Provider ๊ฐ ์ ๊ณตํ๋ value ๊ฐ ๋ฐ๋๋ฉด ์ด๋ฅผ ๋ฐ๋ผ๋ณด๊ณ ์๋(์์กดํ๊ณ ์๋) ProxyProvider ๊ฐ ์ ๊ณตํ๋ ๊ฐ์ด ๋ฐ๋์ด์ผ ํ๋ฏ๋ก update ๊ฐ ์ฌ๋ฌ๋ฒ called ๋๋ ๊ฒ์ ๋งค์ฐ ๋น์ฐํ ์ผ์ด๋ค.


update ๊ฐ ํธ์ถ๋๋ ๊ฒฝ์ฐ๋ค์ ์๋์ ๊ฐ๋ค.
ProxyProvider ๊ฐ ๊ฐ์ฅ ์ฒ์์ผ๋ก ์์กดํ๊ณ ์๋ ๋ค๋ฅธ Provider ์ ๊ฐ์ ์ป์ ๊ฒฝ์ฐ
ProxyProvider ๊ฐ ์์กดํ๊ณ ์๋ ๋ค๋ฅธ Provider ๊ฐ ์ ๊ณตํ๋ ๊ฐ์ด ๋ณ๊ฒฝ๋ ๊ฒฝ์ฐ
ProxyProvider ๊ฐ rebuild ๋๋ ๊ฒฝ์ฐ
ProxyProvider - ๊ฐ์ 2




The instance of MyChangeNotifier is updated whenever myModel changes.
The same instance of MyChangeNotifier is used again and again, not created again. (์๋ก ๋ง๋ค์ด์ง์ง ์๊ณ ํ๋ฒ ๋ง๋ค์ด์ง MyChangeNotifier ๊ฐ ๊ณ์ ์ฌ์ฉ๋๋ค.)

ProxyProvider - ์ค์ต & ์์
create ๋ ํ ๋ฒ๋ง ์คํ๋๋ฏ๋ก increment ์ ์ํด์ counter ๊ฐ์ด ์ฆ๊ฐํด๋ ๊ฒฐ๊ตญ
create: (_) => Translations(counter)์์ ๋ฑ ํ๋ฒ ๋ง๋ค์ด์ง ์ธ์คํด์ค๋ ๋ง๋ค์ด์ง๋ ๋น์์ counter ๋ก ๋ง๋ค์ด์ก๊ธฐ ๋๋ฌธ์final title = Provider.of<Translations>(context).title;์ ๊ฐ์ create ๋ ๋ง๋ค์ด์ง ์ธ์คํด์ค ๊ทธ๋๋ก๋ค.
์ ๊ณตํด์ผํ ๊ฐ์ด ๊ฐ๋ณ์ ์ธ ๊ฐ์ธ counter ์ ์์กดํ๋ ์ธ์คํด์ค์ด๋ฏ๋ก ProxyProvider ๋ฅผ ์ฌ์ฉํด์ค ์ฝ๋์ด๋ค.
์ด๋ฏธ counter ๊ฐ์ด 0 ์ผ๋ก ์ด๊ธฐํ ๋์ด ์์ด์, create ๊ฐ ํ์๊ฐ ์๋ค. ๊ทธ๋ฆฌ๊ณ ์ ๊ณตํด์ผํ ๊ฐ๋ณ ์ธ์คํด์ค๊ฐ ํ๋๋ค. ๊ทธ๋์ ProxyProvider0 ๋ฅผ ์ฌ์ฉํ๋ค.(๊ณต์๋ฌธ์ ์ฐธ๊ณ )
create ์์ ์์ฑ์ ๋จผ์ ํ ์ผ์ด์ค๋ค.
update ์์ create ์์ ์์ฑ๋ ๊ฐ์ฒด๋ฅผ ๋ฐ์ .update() ๋ฅผ call ํ๊ณ return ํ๋ค.
์ฌ๊ธฐ์ ๋ update ๋ฐ์ํ๋ฉด ์ฒ์ create ๋ฐ์์ ๋ง๋ค์ด์ง ์ธ์คํด์ค(= ์ฒ์ update ๋ ์ฌ์ฉ๋)๋ฅผ ๊ณ์ ์ฐธ์กฐํ์ฌ ์ฌํ์ฉํ๋ค. (update ํ๋ค๊ณ ์๋ก ๋ง๋ค์ด์ return ํ๋ ๊ฒ์ด ์๋๋ผ๋ ๊ฒ์ ๋ช ์ฌ)
๋ ๊ฐ์ ProxyProvider ๋ฅผ ์ฌ์ฉํ๋ ์ผ์ด์ค.
ProxyProvider0 ๋ ๊ฐ๋ณ์ ์ธ int value ๋ฅผ return
ProxyProvider ๋ ProxyProvider0 ๊ฐ ์ ๊ณตํ๋ ๊ฐ๋ณ์ ์ธ int ๋ฅผ ๋ฐ์์ ์๋ก์ด ์ธ์คํด์ค๋ฅผ return
์ด ๊ฒฝ์ฐ์ ProxyProvider ๊ฐ ํญ์ ์๋ก์ด ์ธ์คํด์ค๋ฅผ ๋ง๋ค์ด์ return ํ๊ณ ์๋ค๋ ๊ฒ์ ๋ช ์ฌ. ๋งค๋ฒ ์๋ก์ด Translations ๋ฅผ ๋ง๋ค์ด์ return ํ๊ณ ์๋ค.
์ ๋ง ์ฌ๋ฌ๊ฐ์ง ๋ฐฉ์์ผ๋ก ๋์ผํ ๊ฒฐ๊ณผ๋ฅผ ๊ตฌํํ ์ ์๋ค.
Counter ๊ฐ Value Object ๋ก ์ฌ์ฉ ๋์๋ค.
IncreaseButton ์์๋ ๋จ์ง Counter ์ access ๋ง ํ๋ค. increment() ๋ฅผ ์คํํ๊ธฐ๋ง ํ ๋ชฉ์ ์ด๊ธฐ ๋๋ฌธ.
์ง์ ์ ์ดํด๋ณธ ChangeNotifierProvider, ChangeNotifierProxyProvider ์กฐํฉ์ ๊ธฐ์กด์ Translations ๋ฅผ mutation ์์ผ์ ์ฌํ์ฉ ํ๋ ๋ฐ๋ฉด ์ด ๋ฐฉ์์ Counter ๊ฐ ๋ณํ ๋๋ง๋ค ๋งค๋ฒ ์๋ก์ด Translations ์ธ์คํด์ค๋ฅผ return ํ๋ค.
๊ฐ์ฌ๋ ์ด์ผ๊ธฐ๋ก๋ ๋จ์ํ computed state ๋ฅผ ๋ง๋ค์ด ๋ด๋ ๊ฒฝ์ฐ ChangeNotifierProvider ๋ฅผ ์ฐ์ง ์๊ณ ProxyProvider ๋ฅผ ์ฌ์ฉํ๋ ๊ฒ์ด ๋งค๋ด์ผ์๋ ๋์์๋ preferred way ๋ผ๊ณ ํ๋ค.
๋จ์ํ computed state ๋ฅผ ๋ง๋ค์ด ๋ด๋ ๊ฒฝ์ฐ ChangeNotifierProvider ๋ฅผ ์ฐ์ง ์๊ณ ProxyProvider ๋ฅผ ์ฌ์ฉํ๋ ๊ฒ์ด ๋งค๋ด์ผ์๋ ๋์์๋ preferred way ๋ผ๊ณ ํ๋ค.
Errors & addPostFrameCallback - 1



Errors & addPostFrameCallback - 2

์์ ์๋ฌ๋ ์๋์ ๊ฐ์ ์ฝ๋์์ ๋ฐ์๋์๋ค.
flutter ๊ฐ Widget ๋ค์ ๊ทธ๋ฆฌ๊ณ ์๋ ์ค์ ๋ค์ build ์์ฒญ์ ํ ์ ์๋ค๋ ๊ฒ.


addPostFrameCallback ์ ํ์ฌ์ Frame ์ด ์์ฑ๋ ํ ๋ฑ๋ก๋ callback ์ ์คํ์ํค๋๋ก ํ๋ค.
add(์ถ๊ฐ) + PostFrameCallback(Frame ๋ค ๊ทธ๋ ค์ง ํ ๋ถ๋ ค์ง Callback)
UI์ ์ํฅ์ ๋ฏธ์น๋ action ์ ์คํ์ ํ์ฌ์ Frame ์ดํ๋ก ์ง์ฐ์ํฌ ์ ์๋ค. โํ์ฌ์ Frame ์ดํโ ๋ผ๋ ๋ป์ ๊ฒฐ๊ตญ ํ์ฌ ์ธ์ดํด์ build ๊ฐ ๋๋ ํ๋ฅผ ์๋ฏธํ๋ค.
๋ค์ ๋งํ๋ฉด ํด๋น Widget ์ build ๊ฐ ๋๋ ํ ์คํ๋ action ์ ์์ฝํ ์ ์๋ ๊ฒ์ด๋ค.
addPostFrameCallback ์ธ์ ์๋์ ๊ฐ์ ์ฒ๋ฆฌ๋ ๋์ผํ ์๋ฆฌ์ด๋ค.

์ error ๋
context.read์์ read ๋ฅผ watch ๋ก ๋ฐ๊พธ๋ฉด ๋ณผ ์ ์๋ ์๋ฌ์ด๋ค.Widget Tree ๋ฐ์์ listen ์ ํ๋ ค ํ๋ค๋ ๊ฒ.
์๊ฐ์ฐจ๋ฅผ ๋๊ณ ํ์ฌ Frame ๋๋๊ณ ์ด๊ฑธ ์คํํด๋ฌ๋ผ๋ ์์ฝ ํ์์์ listen ์ ํ๋ค๋ ๊ฒ์ด ๋ ผ๋ฆฌ์ ์ผ๋ก ๋ง์ง ์๋ค. ์ด๋ ๊ฒ ์ดํดํ์.
Errors & addPostFrameCallback - 3
Errors & addPostFrameCallback - 3 ์์๋ ํน์ ํ๋ฉด์ ์ง์
ํ์๋ ํน์ ๊ฐ๋ณ์ ์ธ ๊ฐ์ด ํน์ ์กฐ๊ฑด์ ๊ฑธ๋ ธ์ ๋ Dialog ๋ฅผ ๋์ฐ๋ ๊ฒฝ์ฐ์ ์์ด์ ์ฒ๋ฆฌ ๋ฐฉ์ ๋ค์ ์ดํด๋ณธ๋ค.

Dialog ๋ ํด๋น Screen ์ด ๋ค ๊ทธ๋ ค์ง๊ณ ๋์ ๊ทธ ์์ ๊ทธ๋ ค์ง๋ overlay Widget.
๋ฐ๋ผ์ initState ์์ ๊ทธ๋ฅ ํธ์ถ์ ์์ ๊ฐ์ ์๋ฌ๊ฐ ๋ฐ์ํ๋ ๊ฒ์ด ๋น์ฐํ๋ค.
์ด ๊ฒฝ์ฐ๋ ์๋์ ๊ฐ์ด ํด๋น Frame ์ด ๋ค ๊ทธ๋ ค์ง๊ณ ๋์ ๊ทธ ์ดํ์ ๊ทธ๋ ค์ง๋๋ก ์ฒ๋ฆฌํด์ผ ํ๋ค.
๊ฐ์ ๋งฅ๋ฝ์์ ๊ฐ๋ณ์ ์ธ ๊ฐ์ ๋ฐ๋ผ๋ณด๊ณ ํน์ ์กฐ๊ฑด์์ Dialog ๋ฅผ ๋์ฐ๊ณ ์ถ์๋๋ ์๋์ ๊ฐ์ด addPostFrameCallback ๋ก ์ฒ๋ฆฌํด์ค์ผํ๋ค.
ํด๋น Frame ์ด ๋ค ๊ทธ๋ ค์ง๊ณ ๋์ ์ดํ์ ์กฐ๊ฑด ๊ฒ์ฌ๋ฅผ ํ ํ overlay ํ๋ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ด๋ค.
์กฐ๊ฑด์์ ํฌํจํ Dialog call ์์ฒด๋ฅผ ๋ชจ๋ addPostFrameCallback ๋ก ์์ฝํ ์ ์์ผ๋ ์กฐ๊ฑด์ ๋ถํฉํ์ง๋ ์๋ ๊ฒฝ์ฐ์๋ ๋ถํ์ํ๊ฒ action ์ด register ๋๋ฏ๋ก ์ข์ง ์์ ์ฝ๋๊ฐ ๋๋ค.




Errors & addPostFrameCallback - 4
Errors & addPostFrameCallback - 4 ์์๋ State ๊ฐ ๋ณํ ๋ Navigate ํ๋ ๋ฐฉ๋ฒ์ ๋ํด ์ดํด๋ณธ๋ค.

Navigate ํ๋ ๊ฒ๋ ๊ฒฐ๊ตญ Stack ์์ ์ฌ๋ฆฌ๋ Overlay ํ์์ด๊ธฐ ๋๋ฌธ์ ์๋์ ๊ฐ์ด ์์ฝ์ ๊ฑธ์ด ์ฃผ์ด์ผ ํ๋ค.
๋ง์ฝ addPostFrameCallback ๋ฅผ ์ฌ์ฉํ์ง ์์ผ๋ฉด build ํ๋ ์์ค์ Navigator.push ๊ฐ ์ฒ๋ฆฌ ๋๋ ๊ฒ์ด๊ณ ์ด๋ ๋ณธ ํ๋ฉด์ด ๋ค ๊ทธ๋ ค์ง๊ธฐ๋ ์ ์(์ ํํ๋ ๊ทธ๋ ค์ง๋ ์ค๊ฐ์) Overlay ์์ฒญ์ ํ ๊ฒ๊ณผ ๊ฐ๋ค. ๊ทธ๋์ ์์ ๊ฐ์ ์๋ฌ๋ฅผ ๋ง๋๊ฒ ๋๋ค.

Dialog, Navigate, BottomSheet ๋ชจ๋ Overlay Widget ์ด๋ฏ๋ก ํด๋น Widget ์ ์ฌ์ฉํ ๊ฒฝ์ฐ ์ด๋ฒ์ ํ์ตํ ๋ด์ฉ๋ค์ ์ ํ์ฉํ๋๋ก ํ๋ค.
ChangeNotifier ์ addListener ๋ฅผ ์ด์ฉํ action ์ฒ๋ฆฌ





๊ฐ์ฌ๋์ ๋๋ฒ์งธ ํน์ ์ธ๋ฒ์งธ ๋ฐฉ์์ ์ถ์ฒ.
๋๋ฒ์งธ ๋ฐฉ์๋ง ์๋์ ์ฝ๋๋ก ์ ๋ฆฌ.
Last updated