๊ด€๋ฆฌ ๋ฉ”๋‰ด

๋ชฉ๋ก์›น๊ฐœ๋ฐœ (3)

UI Code Lab

๐ŸŽจ ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ์—†์ด CSS + JS๋กœ ๋ถ€๋“œ๋Ÿฌ์šด UI ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐ

์š”์ฆ˜ ์›น์‚ฌ์ดํŠธ ๋ณด๋ฉด ์ธํ„ฐํŽ˜์ด์Šค์— ์• ๋‹ˆ๋ฉ”์ด์…˜์ด ์‚ด์ง ๋“ค์–ด๊ฐ€๋Š” ๊ฒƒ๋งŒ์œผ๋กœ๋„ ํ™• ๋‹ค๋ฅด๊ฒŒ ๋А๊ปด์ง€์ž–์•„์š”? ๊ทผ๋ฐ ๋ง‰์ƒ ๊ตฌํ˜„ํ•˜๋ ค๋ฉด GSAP, Framer Motion ๊ฐ™์€ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ถ€ํ„ฐ ์ƒ๊ฐ๋‚˜๋Š” ๊ฒฝ์šฐ๊ฐ€ ๋งŽ์ฃ . ๊ทธ๋Ÿฐ๋ฐ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ์—†์ด๋„ CSS์™€ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ๋งŒ์œผ๋กœ ์ถฉ๋ถ„ํžˆ ๋ถ€๋“œ๋Ÿฝ๊ณ  ์ž์—ฐ์Šค๋Ÿฌ์šด ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๋งŒ๋“ค ์ˆ˜ ์žˆ๋‹ค๋Š” ๊ฑฐ, ์•Œ๊ณ  ๊ณ„์…จ๋‚˜์š”? ์˜ค๋Š˜์€ ์ •๋ง ๊ฐ€๋ณ๊ฒŒ, ํ•˜์ง€๋งŒ ํ™•์‹คํ•˜๊ฒŒ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ๋Š” ๋ฐฉ๋ฒ•์„ ์•Œ๋ ค๋“œ๋ฆด๊ฒŒ์š”! โœ… ์™œ ๊ตณ์ด CSS + JS๋กœ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๋งŒ๋“ค๊นŒ?๊ฐ„๋‹จํžˆ ๋งํ•˜๋ฉด:๊ฐ€๋ณ๊ณ  ๋น ๋ฆ…๋‹ˆ๋‹ค! ๋กœ๋”ฉ ์†๋„ ๋น ๋ฅธ ์›น์ด ์œ ๋ฆฌํ•˜๋‹ˆ๊นŒ์š”.์กฐ์ ˆ์ด ์ž์œ ๋กญ์Šต๋‹ˆ๋‹ค! CSS๋กœ ๋ชจ์–‘ ๋งŒ๋“ค๊ณ  JS๋กœ ์ƒํ™ฉ์— ๋”ฐ๋ผ ์ œ์–ด๋„ ๊ฐ€๋Šฅํ•ด์š”.๋ธŒ๋ผ์šฐ์ € ํ˜ธํ™˜๋„ ๊ดœ์ฐฎ์•„์š”! ๋Œ€๋ถ€๋ถ„์˜ ์ตœ์‹  ๋ธŒ๋ผ์šฐ์ €์—์„œ ์•„์ฃผ ์ž˜ ์ง€์›๋ฉ๋‹ˆ๋‹ค.์˜ˆ์˜๋ฉด์„œ๋„ ์ตœ์ ํ™”๋œ ์›น์„ ๋งŒ๋“ค..

์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ๋กœ ์Šฌ๋ผ์ด๋“œ ํ† ๊ธ€ ๊ธฐ๋Šฅ ๋งŒ๋“ค๊ธฐ (SlideUp / SlideDown)

์›น ํŽ˜์ด์ง€์—์„œ ์ฝ˜ํ…์ธ ๋ฅผ ๋ถ€๋“œ๋Ÿฝ๊ฒŒ ์ˆจ๊ธฐ๊ฑฐ๋‚˜ ํ‘œ์‹œํ•˜๋Š” ๊ธฐ๋Šฅ์€ ์‚ฌ์šฉ์ž ๊ฒฝํ—˜์„ ํ–ฅ์ƒ์‹œํ‚ค๋Š” ํ•ต์‹ฌ ์š”์†Œ์ž…๋‹ˆ๋‹ค. ํŠนํžˆ SlideUp ๊ณผ SlideDown ํšจ๊ณผ๋Š” ์ง๊ด€์ ์ธ UI๋ฅผ ๊ตฌํ˜„ํ•  ๋•Œ ํฐ ๋„์›€์ด ๋ฉ๋‹ˆ๋‹ค. ์ด ๊ธ€์—์„œ๋Š” jQuery์™€ ์ˆœ์ˆ˜ JavaScript(๋ฐ”๋‹๋ผ JS)๋ฅผ ์‚ฌ์šฉํ•œ ์Šฌ๋ผ์ด๋“œ ํ† ๊ธ€ ๊ธฐ๋Šฅ ๊ตฌํ˜„ ๋ฐฉ๋ฒ•์„ ์†Œ๊ฐœํ•ฉ๋‹ˆ๋‹ค. ๐Ÿ’ก jQuery๋กœ ์Šฌ๋ผ์ด๋“œ ํ† ๊ธ€ ๊ตฌํ˜„jQuery์—์„œ๋Š” .slideUp(), slideDown(), .slideToggle() ๋ฉ”์„œ๋“œ๋ฅผ ์‚ฌ์šฉํ•ด ๊ฐ„ํŽธํ•˜๊ฒŒ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.$(document).ready(function() { $("#toggleButton").click(function() { $("#content").slideToggle(500); // 500ms ๋™์•ˆ ์Šฌ๋ผ์ด..