Framework

์ฐธ๊ณ ์‚ฌ์ดํŠธ • ๋ฆฌ์•กํŠธ ๊ณต์‹ ๋ฌธ์„œ - Custom Hook โš™๏ธ Custom Hook ์•ž์„œ ๊ฒŒ์‹œ๊ธ€์—์„œ ๋‹ค์–‘ํ•œ Hook์„ ์‚ฌ์šฉํ•ด์™”๋‹ค. React์—๋Š” useState, useContext, useEffect์™€ ๊ฐ™์€ ์—ฌ๋Ÿฌ ๋‚ด์žฅ Hook์ด ํ•จ๊ป˜ ์ œ๊ณต๋œ๋‹ค. ๋ฐ์ดํ„ฐ๋ฅผ ๊ฐ€์ ธ์˜ค๊ฑฐ๋‚˜, ์‚ฌ์šฉ์ž๊ฐ€ ์˜จ๋ผ์ธ ์ƒํƒœ์ธ์ง€ ์ถ”์ ํ•˜๊ฑฐ๋‚˜ ์ฑ„ํŒ…๋ฐฉ์— ์—ฐ๊ฒฐํ•˜๋Š” ๋“ฑ ์ข€ ๋” ๊ตฌ์ฒด์ ์ธ ๋ชฉ์ ์„ ์œ„ํ•ด Hook์ด ์žˆ์—ˆ์œผ๋ฉด ํ•˜๋Š” ๊ฒฝ์šฐ๊ฐ€ ์žˆ๋‹ค. React์—์„œ ์ด๋Ÿฌํ•œ Hook์„ ๋ชจ๋‘ ์ง€์›ํ•  ์ˆ˜ ์—†๋‹ค. ๊ทธ๋ž˜์„œ ์–ดํ”Œ๋ฆฌ์ผ€์ด์…˜ ์š”๊ตฌ์‚ฌํ•ญ์— ๋งž๊ฒŒ ์ง์ ‘ ์ž์‹ ๋งŒ์˜ Hook์„ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋‹ค. ๐Ÿง ์™œ ์‚ฌ์šฉํ• ๊นŒ? ์žฌ์‚ฌ์šฉ์„ฑ์ด ๋†’์•„ ์ฝ”๋“œ๊ฐ€ ๊ฐ„๊ฒฐํ•ด์ง„๋‹ค. ๋‚ด์žฅ Hook์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค. ๋…๋ฆฝ์ ์œผ๋กœ ๋™์ž‘ํ•œ๋‹ค. ๐Ÿ“ก ๊ตฌ์„ฑ์š”์†Œ ๊ฐ„ ๋…ผ๋ฆฌ ๊ณต์œ  ๋„คํŠธ์›Œํฌ์— ํฌ๊ฒŒ ์˜์กดํ•˜๋Š” ์•ฑ์ด ์žˆ๋‹ค๊ณ  ์ƒ์ƒํ•ด๋ณด์ž. ..
์ฐธ๊ณ ์‚ฌ์ดํŠธ โˆ™ ์ฝ”๋”ฉ์• ํ”Œ์˜ flutter-basic-layout-design ๋‚ด๊ฐ€ ์ข‹์•„ํ•˜๋Š” ๊ฐœ๋ฐœ์ž ์œ ํŠœ๋ฒ„ ๐Ÿœ Scaffold ์šฐ๋ฆฌ๊ฐ€ ์“ฐ๋Š” ์•ฑ์˜ ๋””์ž์ธ์€ ํฌ๊ฒŒ ์ƒ๋‹จ, ์ค‘๋‹จ, ํ•˜๋‹จ๋ถ€๋กœ ์ด๋ฃจ์–ด์ ธ์žˆ๋‹ค. ์ด๊ฑธ ์‰ฝ๊ฒŒ ๊ตฌ์„ฑํ•˜๊ณ  ์‹ถ์œผ๋ฉด Scaffold() ์œ„์ ฏ์„ ์‚ฌ์šฉํ•˜๋ฉด ๋œ๋‹ค. ๐Ÿ‘ท๐Ÿป ๊ตฌ์กฐ MaterialApp( home: Scaffold( appBar: // ์ƒ๋‹จ์— ๋„ฃ์„ ์œ„์ ฏ, body:// ์ค‘๋‹จ์— ๋„ฃ์„ ์œ„์ ฏ, bottomNavigationBar:// ํ•˜๋‹จ์— ๋„ฃ์„ ์œ„์ ฏ, ) ); Scaffold() ์œ„์ ฏ์€ 3๊ฐœ์˜ ํŒŒ๋ผ๋ฏธํ„ฐ(appBar, body, bottomNavigationBar)๋ฅผ ํ†ตํ•ด ์ƒ/์ค‘/ํ•˜๋กœ ๋‚˜๋‰˜๊ฒŒ ํ•ด์ค€๋‹ค. appBar(์ƒ๋‹จ), bottomNavigationBar(ํ•˜๋‹จ)์€ ํ•„์ˆ˜๊ฐ€ ์•„๋‹ˆ๊ณ  body(์ค‘๋‹จ)์€ ํ•„์ˆ˜..
์ฐธ๊ณ ์‚ฌ์ดํŠธ โˆ™ deku๋‹˜์˜ ํฌ์ŠคํŠธ๋ฆฌ ๐Ÿ”ฉ Widget Flutter๋Š” ํ™”๋ฉด์€ ์œ„์ ฏ์—์„œ ์‹œ์ž‘ํ•ด์„œ ์œ„์ ฏ์œผ๋กœ ๋๋‚œ๋‹ค. widget์ด๋ž€ Flutter์—์„œ ํ™”๋ฉด์— ํ‘œ์‹œ๋œ ๋ชจ๋“  ์š”์†Œ๊ฐ€ ์œ„์ ฏ์ด๋ฉฐ, ๋ˆˆ์— ๋ณด์ด์ง€ ์•Š์ง€๋งŒ ํ™”๋ฉด์„ ๊ตฌ์„ฑํ•˜๋Š” ๋ ˆ์ด์•„์›ƒ(Layout) ๋˜ํ•œ ์œ„์ ฏ์ด๋‹ค. ํ”Œ๋Ÿฌํ„ฐ์˜ ์œ„์ ฏ์€ ํฌ๊ฒŒ 2๊ฐ€์ง€๊ฐ€ ์กด์žฌํ•œ๋‹ค. ๐Ÿ˜ถ Stateless Widget ๊ฐ’์€ ๊ฐ€์ง€๊ณ  ์žˆ์„ ์ˆ˜ ์žˆ์œผ๋‚˜ ์–ด๋– ํ•œ ๋™์ž‘์„ ํ•˜๋”๋ผ๋„ ๋ณ€ํ•˜์ง€ ์•Š๋Š” ์œ„์ ฏ์„ ๋‚˜ํƒ€๋‚ธ๋‹ค. ํ•ด๋‹น ์œ„์ ฏ์€ Flutter์— StatelessWidget์„ ์ƒ์†๋ฐ›์•„ ์ƒ์„ฑํ•œ๋‹ค. ๐Ÿซจ Stateful Widget ์–ด๋– ํ•œ ์ƒํƒœ๊ฐ’(๋ฐ์ดํ„ฐ)์„ ๊ฐ€์ง€๊ณ  ์žˆ๋‹ค๊ฐ€ ํ•ด๋‹น ์ƒํƒœ๊ฐ’์ด ๋ณ€๊ฒฝ๋˜๋ฉด ๋ณ€๊ฒฝ์‚ฌํ•ญ์„ ์ธ์ง€ํ•˜๊ณ  ํ•ด๋‹น ์œ„์ ฏ์„ ๋‹ค์‹œ ๊ทธ๋ ค์ค€๋‹ค. (๋ฆฌ-๋ Œ๋”๋ง) ex. TextField, Button, ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ์ „๋‹ฌ๋ฐ›์€ ..
๐Ÿ› ๏ธ Flutter Flutter๋Š” Google์—์„œ ๊ฐœ๋ฐœํ•˜๊ณ  ์ง€์›ํ•˜๋Š” ์˜คํ”ˆ ์†Œ์Šค ๋ชจ๋ฐ”์ผ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ๊ฐœ๋ฐœ ํ”„๋ ˆ์ž„์›Œํฌ์ž…๋‹ˆ๋‹ค. ์ด ์„น์…˜์—์„œ๋Š” Flutter ๊ฐœ๋ฐœํ™˜๊ฒฝ ์„ค์ •์— ๋Œ€ํ•ด ์„ค๋ช…ํ•ฉ๋‹ˆ๋‹ค. ๐Ÿบ Homebrew ์„ค์น˜ Homebrew๋Š” macOS์˜ ํŒจํ‚ค์ง€ ๊ด€๋ฆฌ์ž์ž…๋‹ˆ๋‹ค. ํ•ด๋‹น ํŒจํ‚ค์ง€ ๊ด€๋ฆฌ์ž๋ฅผ Terminal์—์„œ ๋ช…๋ น์–ด๋ฅผ ์ด์šฉํ•˜์—ฌ ํŒจํ‚ค์ง€๋ฅผ ์„ค์น˜ํ•˜๊ณ , ๋Œ€๋ถ€๋ถ„ ๋ณ„๋„์˜ Path ์„ค์ • ์—†์ด ํ™˜๊ฒฝ๋ณ€์ˆ˜ ์„ค์ •์„ ๋„์™€์ค๋‹ˆ๋‹ค. ๐Ÿ”ง Dart ์„ค์น˜ Dart๋Š” Flutter์— ์‚ฌ์šฉ๋˜๋Š” ๊ฐœ๋ฐœ ์–ธ์–ด์ž…๋‹ˆ๋‹ค. # Dart์˜ ์„ค์น˜ ์—ฌ๋ถ€๋ฅผ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค. $ brew -v # ์„ค์น˜ ์•ˆ ๋˜์–ด ์žˆ์„ ์‹œ, $ brew install dart ๐Ÿ”จ Xcode ์„ค์น˜ App Store์—์„œ Xcode๋ฅผ ์„ค์น˜ํ•˜์—ฌ ์—๋ฎฌ๋ ˆ์ดํ„ฐ์— ์‚ฌ์šฉ๋  ์†Œํ”„ํŠธ์›จ์–ด๋ฅผ ์„ค์น˜ํ•ฉ๋‹ˆ๋‹ค. ํ•ด๋‹น ๊ธฐ..
์ฐธ๊ณ ์‚ฌ์ดํŠธ • ๋ฆฌ์•กํŠธ ๊ณต์‹ ๋ฌธ์„œ - useContext ๐ŸŒ useContext useContext๋Š” ์ปดํฌ๋„ŒํŠธ์˜ Context๋ฅผ ์ฝ๊ณ  ๊ตฌ๋…ํ•˜๊ฒŒ ํ•ด์ฃผ๋Š” ๋ฆฌ์•กํŠธ Hook์ด๋‹ค. ๋ฆฌ์•กํŠธ์—์„œ ๋ฐ์ดํ„ฐ๊ฐ’์„ ํ•˜์œ„ ์ปดํฌ๋„ŒํŠธ๋กœ ์ „๋‹ฌํ•˜๊ธฐ ์œ„ํ•ด ์ปดํฌ๋„ŒํŠธ ํ˜ธ์ถœ ์‹œ, ๋ฐ์ดํ„ฐ prop์„ ๋‹ด๊ณ , ํ•ด๋‹น props๋ฅผ ์ด์šฉํ•˜์—ฌ ๋ฐ์ดํ„ฐ๋ฅผ ์‚ฌ์šฉํ•œ๋‹ค. useContext๋Š” ํ•ด๋‹น ๊ณผ์ •์— ์ƒ๊ด€์—†์ด useContext๋กœ ๊ฐ์‹ผ ์ปดํฌ๋„ŒํŠธ๋“ค์„ ํ•ด๋‹น ๋ฐ์ดํ„ฐ๋ฅผ ์ ‘๊ทผํ•  ์ˆ˜ ์žˆ๋„๋ก ๋„์™€์ค€๋‹ค. ๋น„์Šทํ•œ ๊ธฐ๋Šฅ์˜ ์™ธ๋ถ€ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋กœ๋Š” recoil์ด ์žˆ๋‹ค. ๐Ÿ“ฆ Parameter useContext ์ปจํ…์ŠคํŠธ๋ฅผ ์ฝ๊ณ  ๊ตฌ๋…ํ•˜๋ ค๋ฉด ์ปดํฌ๋„ŒํŠธ ์ตœ์ƒ์œ„์—์„œ ํ˜ธ์ถœํ•ด์•ผํ•œ๋‹ค. const value = useContext(SomeContext); • SomeContext: ํ•ด๋‹น ์ปจํ…์ŠคํŠธ๋Š” cr..
์ฐธ๊ณ  ์‚ฌ์ดํŠธ • ๋ฆฌ์•กํŠธ ๊ณต์‹ ๋ฌธ์„œ - useCallback • ๋ณ„์ฝ”๋”ฉ๋‹˜์˜ youtube - useCallback ๊ฐ•์˜ ๐Ÿชฃ useCallback useCallback์€ ์žฌ๋ Œ๋”๋ง ์‚ฌ์ด์— ํ•จ์ˆ˜ ์ •์˜๋ฅผ ์บ์‹œํ•  ์ˆ˜ ์žˆ๋Š” React Hook์ด๋‹ค. ๐Ÿ“ข ์ฐธ์กฐ useCallback ์žฌ๋ Œ๋”๋ง ์‚ฌ์ด์— ํ•จ์ˆ˜ ์ •์˜๋ฅผ ์บ์‹œํ•˜๋ ค๋ฉด ๊ตฌ์„ฑ ์š”์†Œ์˜ ์ตœ์ƒ์œ„ ์ˆ˜์ค€์—์„œ ํ˜ธ์ถœํ•˜๋ฉด ๋œ๋‹ค. const cachedFn = useCallback(fn, [dependencies]); ๐Ÿ“ฆ Parameters • fn: ์บ์‹œํ•˜๋ ค๋Š” ํ•จ์ˆ˜์ด๋‹ค. ๋ชจ๋“  ์ธ์ˆ˜๋ฅผ ์ทจํ•˜๊ณ  ๋ชจ๋“  ๊ฐ’์„ ๋ฐ˜ํ™˜ํ•  ์ˆ˜ ์žˆ๋‹ค. React๋Š” ์ดˆ๊ธฐ ๋ Œ๋”๋ง ์ค‘์— ํ•จ์ˆ˜๋ฅผ ๋‹ค์‹œ ๋ฐ˜ํ™˜ํ•œ๋‹ค(ํ˜ธ์ถœX). ๋‹ค์Œ ๋ Œ๋”๋ง์—์„œ dependencies๊ฐ€ ๋ณ€๊ฒฝ๋˜์ง€ ์•Š์€ ๊ฒฝ์šฐ ๋™์ผํ•œ ๊ธฐ๋Šฅ์„ ๋‹ค์‹œ ์ œ๊ณตํ•˜๋ฉฐ, ๊ทธ๋ ‡์ง€ ์•Š๋‹ค๋ฉด ..
์ฐธ๊ณ  ์‚ฌ์ดํŠธ • ๋ฆฌ์•กํŠธ ๊ณต์‹ ๋ฌธ์„œ - useMemo ๐Ÿ“ useMemo useMemo๋Š” ์žฌ๋ Œ๋”๋ง ๊ฐ„ ๊ณ„์‚ฐ ๊ฒฐ๊ณผ๋ฅผ *์บ์‹œ(Cache)ํ•  ์ˆ˜ ์žˆ๋Š” React Hook์ด๋‹ค. ๋น„์šฉ์ด ๋งŽ์ด ๋“œ๋Š” ์žฌ๊ณ„์‚ฐ์„ ๊ฑด๋„ˆ๋›ฐ๊ธฐ ์œ„ํ•˜์—ฌ ์‚ฌ์šฉํ•œ๋‹ค. *์บ์‹œ(Cache): ์ปดํ“จํ„ฐ ๊ณผํ•™์—์„œ ๋ฐ์ดํ„ฐ๋‚˜ ๊ฐ’์„ ๋ฏธ๋ฆฌ ๋ณต์‚ฌํ•ด ๋†“๋Š” ์ž„์‹œ ์žฅ์†Œ๋กœ ๋ฐ์ดํ„ฐ ์ ‘๊ทผํ•˜๋Š” ์‹œ๊ฐ„์ด ์˜ค๋ž˜๊ฑธ๋ฆฌ๊ฑฐ๋‚˜ ๋‹ค์‹œ ๊ณ„์‚ฐํ•˜๋Š” ์‹œ๊ฐ„์„ ์ ˆ์•ฝํ•˜๊ณ  ์‹ถ์€ ๊ฒฝ์šฐ์— ์‚ฌ์šฉ ์ถœ์ฒ˜: Wikipedia ๋ฐ˜ํ™˜๊ฐ’์„ ์บ์‹ฑํ•˜๋Š” ๊ฒƒ์„ ๋ฉ”๋ชจ์ด์ œ์ด์…˜(memoization)์ด๋ผ๊ณ ๋„ ํ•˜๋ฉฐ, ์ด๊ฒƒ์ด ์ด Hook์ด ๋ถˆ๋ฆฌ๋Š” ์ด์œ ์ด๋‹ค. ๐Ÿ“ข ์ฐธ์กฐ useMemo ์žฌ๋ Œ๋”๋ง ๊ฐ„์˜ ๊ณ„์‚ฐ์„ ์บ์‹œํ•˜๋ ค๋ฉด ๊ตฌ์„ฑ ์š”์†Œ์˜ ์ตœ์ƒ์œ„ ์ˆ˜์ค€์—์„œ ํ˜ธ์ถœํ•œ๋‹ค. const cachedValue = useMemo(calculateValue, [depende..
์ฐธ๊ณ ์‚ฌ์ดํŠธ • React ๊ณต์‹ ๋ฌธ์„œ - useRef ๐Ÿชฃ useRef ๋ Œ๋”๋ง์ด ํ•„์š”ํ•˜์ง€ ์•Š์€ ๊ฐ’์„ ์ฐธ์กฐํ•  ์ˆ˜ ์žˆ๋Š” React Hook์ด๋‹ค. useRef๋Š” .current ํ”„๋กœํผํ‹ฐ๋กœ ์ „๋‹ฌ๋œ ์ธ์ž(initialValue)๋กœ ์ดˆ๊ธฐํ™”๋œ ๋ณ€๊ฒฝ ๊ฐ€๋Šฅํ•œ ref ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค. ๋ฐ˜ํ™˜๋œ ๊ฐ์ฒด๋Š” ์ปดํฌ๋„ŒํŠธ์˜ ์ „ ์ƒ์• ์ฃผ๊ธฐ๋ฅผ ํ†ตํ•ด ์œ ์ง€๋œ๋‹ค. ๐Ÿ“ฆ Parameter • initialValue: ์ดˆ๊ธฐ์— ์ €์žฅ๋˜๋Š” ๊ฐ’์„ ๋„ฃ์œผ๋ฉฐ, ๋ชจ๋“  ์œ ํ˜•์˜ ๊ฐ’์ด(lite, DOM...)์ด ๋  ์ˆ˜ ์žˆ๋‹ค. ์ด ์ธ์ˆ˜๋Š” ์ดˆ๊ธฐ ๋ Œ๋”๋ง ํ›„์— ๋ฌด์‹œ๋œ๋‹ค. ๐ŸŽ Return useRef๋Š” ๋‹จ์ผ ์†์„ฑ์„ ๊ฐ€์ง„ ๊ฐ์ฒด๋ฅผ ๋ฐ˜ํ™˜ํ•œ๋‹ค. {current: value} • current: initialValue๊ฐ’์ด ๋“ค์–ด๊ฐ€ ์žˆ์œผ๋ฉฐ null์„ ์‚ฌ์šฉํ•ด๋„ ๋œ๋‹ค. ํ–ฅํ›„ ๋‹ค๋ฅธ ๊ฒƒ์œผ๋กœ ์„ค์ •ํ•  ์ˆ˜ ..
ma.caron_g
'Framework' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๊ธ€ ๋ชฉ๋ก