์ƒ์„ธ ์ปจํ…์ธ 

๋ณธ๋ฌธ ์ œ๋ชฉ

classnames ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋™์  class ์ถ”๊ฐ€ํ•˜๊ธฐ

Project Log

by loeybho 2024. 6. 14. 13:11

๋ณธ๋ฌธ

๊ณต๋ถ€ ๊ณ„๊ธฐ ๐Ÿ“š

https://byolsfolio.netlify.app/

์ธํ„ฐ๋ž™ํ‹ฐํ”„ ํฌํŠธํด๋ฆฌ์˜ค๋ฅผ ๋งŒ๋“œ๋Š” ์ค‘, hover๋ฅผ ํ•˜๋ฉด ๋ฐ์ดํ„ฐ์— ์žˆ๋Š” ์›ํ•˜๋Š” ๋ฐฐ๊ฒฝํ™”๋ฉด ์ƒ‰์ƒ์ด ๋‚˜์˜ค์ง€ ์•Š๋Š” ์ƒํ™ฉ์ด ๋ฐœ์ƒํ–ˆ๋‹ค.

 

๋ฌธ์ œ ์›์ธ ๐Ÿ“ƒ

Tailwind CSS ์„ค์ •์€ ๋งž์€ ์ƒํƒœ์ธ๋ฐ, Tailwind CSS์˜ ‘hover’์ƒํƒœ ํด๋ž˜์Šค๋Š” ์ง์ ‘ ๋ฌธ์ž์—ด ํ…œํ”Œ๋ฆฟ์œผ๋กœ ๋™์ ์œผ๋กœ ์ถ”๊ฐ€ํ•  ๋•Œ ์›ํ™œํžˆ ์ถ”๊ฐ€๋˜์ง€ ์•Š๋Š” ๊ฒฝ์šฐ๊ฐ€ ์žˆ๋‹ค.

 

Tailwind CSS๊ฐ€ ๋นŒ๋“œ ๊ณผ์ •์—์„œ ๋™์ ์œผ๋กœ ์ƒ์„ฑ๋˜๋Š” ํด๋ž˜์Šค๋ฅผ ๋ฏธ๋ฆฌ ์ธ์‹ํ•˜์ง€ ๋ชปํ•˜๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค. Tailwind CSS๋Š” ๋นŒ๋“œ ์‹œ, ์‚ฌ์šฉ๋˜๋Š” ํด๋ž˜์Šค๋ฅผ ๋ถ„์„ํ•˜์—ฌ CSS๋ฅผ ์ƒ์„ฑํ•œ๋‹ค. ๋งŒ์•ฝ ํด๋ž˜์Šค ์ด๋ฆ„์ด ๋ฌธ์ž์—ด ํ…œํ”Œ๋ฆฟ์ด๋‚˜ ๋™์  ๋ณ€์ˆ˜๋กœ ์ง€์ •๋œ ๊ฒฝ์šฐ, Tailwind๋Š” ์ด๋ฅผ ๊ฐ์ง€ํ•˜์ง€ ๋ชปํ•˜๊ณ  CSS๋ฅผ ์ƒ์„ฑํ•˜์ง€ ์•Š์„ ์ˆ˜ ์žˆ๋‹ค.

 

 

ํ•ด๊ฒฐ ๋ฐฉ๋ฒ• ๐Ÿ“ƒ

classnames ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ์—ˆ๋‹ค.

 

classnames ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋Š” ๋™์ ์œผ๋กœ ํด๋ž˜์Šค ์ด๋ฆ„์„ ๊ฒฐํ•ฉํ•˜๊ฑฐ๋‚˜, ์กฐ๊ฑด๋ถ€๋กœ ํด๋ž˜์Šค๋ฅผ ์ถ”๊ฐ€ํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋œ๋‹ค. ํŠนํžˆ React์™€ ๊ฐ™์€ ํ”„๋ ˆ์ž„์›Œํฌ์—์„œ ์œ ์šฉํ•˜๊ฒŒ ์‚ฌ์šฉ๋œ๋‹ค.

 

 

ํ™œ์šฉ ์˜ˆ์‹œ ๐Ÿช„

npm install classnames

 

1. ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ์„ค์น˜

 

 

import classNames from "classnames";

 

2. ์‚ฌ์šฉํ•  ๊ณณ์— ํ•ด๋‹น ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ์ž„ํฌํŠธ

 

 

3. ์ˆ˜์ • ์ „ ์ฝ”๋“œ

<div
	className={`transition duration-300 ease-in-out font-NanumSquareNeo hover:text-customBlack grid grid-cols-1 sm:grid-cols-[1fr_2fr] group mb-8 hover:${project.hoverColor}`}
>

 

 

4. ์ˆ˜์ • ํ›„ ์ฝ”๋“œ

            <div
              className={classNames(
                "transition",
                "duration-300",
                "ease-in-out",
                "font-NanumSquareNeo",
                "hover:text-customBlack",
                "grid",
                "grid-cols-1",
                "sm:grid-cols-[1fr_2fr]",
                "group",
                "mb-8",
                project.hoverColor // Apply the dynamic hover color class
              )}
            >

 

 

์ด๋ ‡๊ฒŒ ํ•˜๋ฉด ๋ฐ์ดํ„ฐ๊ฐ€ ๋ฐ˜์˜๋œ ํ˜ธ๋ฒ„ ๊ธฐ๋Šฅ์ด ๋™์ž‘๋˜๋Š” ๊ฒƒ์„ ์•Œ ์ˆ˜ ์žˆ๋‹ค.

๊ด€๋ จ๊ธ€ ๋”๋ณด๊ธฐ