TIL 4

์†œ์ฃผ๋จนยท2022๋…„ 8์›” 7์ผ
0

TIL

๋ชฉ๋ก ๋ณด๊ธฐ
4/6
post-custom-banner

๐Ÿ“ขNotice

  • ๊ตฌ์–ด์ฒด๋กœ ์ž‘์„ฑ๋˜์–ด ์žˆ์–ด ์•Œ์•„๋ณด๊ธฐ ํž˜๋“ค ์ˆ˜ ์žˆ์Œ
  • ๋ฐ€๋ ค์žˆ๋˜ TIL์„ ์ •๋ฆฌํ•ด๋†“์€ ๊ฒƒ
  • ์–ธ์ œ ๋ฐฐ์› ๋Š”์ง€ ๋‚ ์งœ๊ฐ€ ๊ธฐ์–ต ์•ˆ๋‚จ (์•„๋งˆ๋„ 7์›” 29์ผ)



๐Ÿ“Œ Styled-components

๐Ÿ“– ์„ค์น˜

  • ๋ฆฌ๋•์Šค์™€ ๋ฆฌ์•กํŠธ์šฉ ๋ฆฌ๋•์Šค ์„ค์น˜
yarn add styled-components

๐Ÿ“– ์ด๊ฒŒ ๋ญ์ง€?

  • ๊ทธ๋ƒฅ css ์ฝ”๋“œ ์ ์šฉ๋œ HTML ์—˜๋ฆฌ๋จผํŠธ ๋งŒ๋“ค์–ด๋‚ด๋Š” ๊ฑฐ ๊ฐ™์€ ๋Š๋‚Œ์ ์ธ ๋Š๋‚Œ
  • ๊ณ ์ • ์Šคํƒ€์ผ๋ง๊ณผ props๋ฅผ ํ†ตํ•œ ๊ฐ€๋ณ€ ์Šคํƒ€์ผ๋ง ๊ฐ€๋Šฅํ•จ(์ œ๊ณตํ•˜๋Š” cssํ•จ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์—ฌ๋Ÿฌ๊ฐœ ์†์„ฑ ๋ฌถ์–ด์„œ๋„ ๊ฐ€๋Šฅ)

๐Ÿ“– createGlobalStyle

  • ์ „์—ญ ์Šคํƒ€์ผ ์ ์šฉ๋„ ๊ฐ€๋Šฅํ•จ

๐Ÿ“– css nesting(์ค‘์ฒฉ)

  • ํ˜‘์—… ์‹œ .cssํŒŒ์ผ์„ ๋”ฐ๋กœ ๋งŒ๋“ค๋‹ค๊ฐ€ ํ•ฉ์น˜๋ฉด ํด๋ž˜์Šค ๋ช…์ด ์ค‘์ฒฉ๋˜๋Š” ๊ฒฝ์šฐ ๋ฐœ์ƒ
  • ๋Œ€์•ˆ : sass์‚ฌ์šฉ๋„ ์žˆ๋Š”๋ฐ styled-components๋กœ ํ•˜๊ธฐ๋„ํ•จ

๐Ÿ“Œ ์ถ”๊ฐ€ ๋„์ ์ธ๊ฑฐ

๐Ÿ“– useState

  • setState์˜ ํ•จ์ˆ˜ํ˜• ์—…๋ฐ์ดํŠธ ๋ฐฉ์‹(()=>{}) : ๋ฐฐ์น˜(batch)์— ์˜ํ–ฅ๋ฐ›์ง€์•Š์Œ

๐Ÿ“– useEffect

  • ์˜์กด์„ฑ ๋ฐฐ์—ด์ด๋ž€? : ๋ฐฐ์—ด์•ˆ์— ์žˆ๋Š”๊ฒŒ ๋ฐ”๋€Œ์—ˆ์„๋•Œ๋งŒ ์‹คํ–‰ํ•˜๋„๋ก ํ•ด์ฃผ๋Š”๊ฑฐ, ๋นˆ๋ฐฐ์—ด๋กœ ์ฃผ๋ฉด ์ฐธ์กฐ๊ฐ€ ์—†๊ธฐ์— ํ•œ๋ฒˆ๋งŒ ์‹คํ–‰
  • ํด๋ฆฐ์—… : useEffect์˜ return๋ถ€๋ถ„์„ ๊ทธ๋ ‡๊ฒŒ ๋ถ€๋ฅด๋Š”๋“ฏ

๐Ÿ“– ๋ฆฌ๋•์Šค ์šฉ์–ด

  • ๋ชฉ์ ์–ด๋„ ์•ก์…˜๊ฐ์ฒด์— ๋‹ด์•„ ๊ฐ™์ด ๋ณด๋‚ด์ค˜์•ผ ํ•  ๊ฒƒ
  • ์ด๋ ‡๊ฒŒ ์•ก์…˜๊ฐ์ฒด์— ๊ฐ™์ด ๋‹ด์•„ ๋ณด๋‚ด์ฃผ๋Š” ๊ทธ ๊ฒƒ์„ payload๋ผ ๋ถ€๋ฆ„

๐Ÿ’ก ๋„์ ์˜€๋˜ ์›๋ณธ ํ…์ŠคํŠธํŒŒ์ผ

  • ๋‚จ๋ณด์—ฌ์ฃผ๊ธด ๋ถ€๋„๋Ÿฌ์›Œ์„œ ๋ ˆํฌ๋ฅผ private๋กœ ๋Œ๋ ค๋†จ๋‹ค
  • ๊ทธ๋ž˜์„œ ๋‚˜๋งŒ ๋ณผ์ˆ˜ ์žˆ์„๊ฑฐ๊ฐ™๋‹ค
    somfist-github
post-custom-banner

0๊ฐœ์˜ ๋Œ“๊ธ€