useRef

์ง€๋‚œ ๊ฒŒ์‹œ๊ธ€์—์„œ ์ˆซ์ž ์ž…๋ ฅํ•  ๋•Œ ์ž๋™์œผ๋กœ ์‹œ๊ฐ„ ๊ตฌ๋ถ„ (":") ํ•ด์ฃผ๋Š”๊ฑฐ๋ž‘ ์—”ํ„ฐํ‚ค ์ž…๋ ฅ์œผ๋กœ + ๊ตฌํ˜„์„ ํ–ˆ๋‹ค. ๊ทผ๋ฐ ๋‚ด๊ฐ€ ์›ํ•˜๋Š” ๊ฒƒ์€ ๊ทผ๋ฌด ์‹œ๊ฐ„์„ ์ „๋ถ€ ๋”ํ•ด์•ผํ•˜๊ธฐ ๋•Œ๋ฌธ์—, ๋”ํ•œ ๊ฒƒ์— ๋˜ ๋”ํ•˜๊ณ  ๋˜ ๋”ํ•˜๊ณ  ๋˜ ๋”ํ•˜๋Š” ์ด๋Ÿฐ~ ๊ณ„์‚ฐ๊ธฐ ๊ฐ™์€ ๊ธฐ๋Šฅ์ด ํ•„์š”ํ–ˆ๋‹ค. ์‹œ๊ฐ„ ๋ˆ„์ ํ•ด์„œ ๋”ํ•˜๊ธฐ const result = `${adjustedHours .toString() .padStart(2, "0")}:${adjustedMinutes.toString().padStart(2, "0")}`; setState({ time1: result, time2: "", result: "", }); ๊ฒฐ๊ณผ๊ฐ’์— (๋ง์…ˆ์„ ํ•œ ํ›„) result ๋ฅผ time1์— ๋„ฃ์–ด์ค€๋‹ค. ๊ทธ๋ฆฌ๊ณ  ์›๋ž˜ time2 ์˜ ์ดˆ๊ธฐ๊ฐ’์ด 00:00 ์ด์—ˆ๋Š”๋ฐ ์ด๊ฒƒ๋„ ๋นˆ ๋ฌธ์ž์—ด๋กœ ๋ฐ”๊พธ์–ด..
๋ฆฌ์•กํŠธ๋ฅผ ์‚ฌ์šฉํ•  ๋•Œ DOM ์„ ์ง์ ‘ ์„ ํƒํ•ด์•ผ ํ•˜๋Š” ์ƒํ™ฉ์—์„œ useRef๋ฅผ ์ด์šฉํ•œ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด์„œ ํŠน์ • ์—˜๋ฆฌ๋จผํŠธ์˜ ํฌ๊ธฐ๋ฅผ ๊ฐ€์ ธ์™€์•ผ ํ•œ๋‹ค๋˜์ง€, ์Šคํฌ๋กค๋ฐ” ์œ„์น˜๋ฅผ ๊ฐ€์ ธ์˜ค๊ฑฐ๋‚˜ ์„ค์ •ํ•ด์•ผ๋œ๋‹ค๋˜์ง€, ๋˜๋Š” ํฌ์ปค์Šค๋ฅผ ์„ค์ •ํ•ด์ค˜์•ผ๋œ๋‹ค๋˜์ง€ ๋“ฑ ์ •๋ง ๋‹ค์–‘ํ•œ ์ƒํ™ฉ์ด ์žˆ์„ ๊ฒƒ์ž„. https://react.vlpt.us/basic/10-useRef.html ์ž์„ธํ•œ ์„ค๋ช…์€ ์—ฌ๊ธฐ ๋‚˜์™€์žˆ๊ณ , ๋‚˜๋Š” ๋‚ด๊ฐ€ ์ง„ํ–‰ํ–ˆ๋˜ ํ”„๋กœ๊ทธ๋žจ ๊ธฐ์ค€์œผ๋กœ ๊ณต๋ถ€ํ•ด๋ณด๋ ค๊ณ  ํ•จ DiaryEditor.js const contentRef = useRef(); ... contentRef.current.focus(); useRef() ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ Ref ๊ฐ์ฒด๋ฅผ ๋งŒ๋“ค๊ณ , ์ด ๊ฐ์ฒด๋ฅผ ์šฐ๋ฆฌ๊ฐ€ ์„ ํƒํ•˜๊ณ  ์‹ถ์€ DOM ์— ref ๊ฐ’์œผ๋กœ ์„ค์ •ํ•ด์ค€๋‹ค. ๊ทธ๋Ÿฌ๋ฉด Ref ๊ฐ์ฒด์˜ .current ๊ฐ’์€..
Dong _ hwa
'useRef' ํƒœ๊ทธ์˜ ๊ธ€ ๋ชฉ๋ก