๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ

์• ๋‹ˆ๋ฉ”์ด์…˜6

[Parallax Effect] ํŒจ๋Ÿด๋Ÿญ์Šค ์ดํŽ™ํŠธ 04 - ๋ถ€๋“œ๋Ÿฝ๊ฒŒ ๋‚˜ํƒ€๋‚ด๊ธฐ ํŒจ๋Ÿด๋Ÿญ์Šค ์ดํŽ™ํŠธ 04 ์ด๋ฒˆ ์‹œ๊ฐ„์—๋Š” ๊ทธ ๋™์•ˆ ๋ฐฐ์› ๋˜ JavaScript๋ฅผ ์ด์šฉํ•˜์—ฌ ํŒจ๋Ÿด๋Ÿญ์Šค(parallax, ํŒจ๋Ÿด๋ž™์Šค) ์ดํŽ™ํŠธ๋ฅผ ๋งŒ๋“ค์–ด๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. ๋จผ์ € parallax๋ž€, '์‹œ์ฐจ(่ฆ–ๅทฎ)'๋ผ๋Š” ์˜๋ฏธ๋ฅผ ๊ฐ€์ง„ ์ฒœ๋ฌธํ•™ ์šฉ์–ด์ด๋ฉฐ, ์ด๋ฒˆ ํฌ์ŠคํŒ…์—์„œ ๋‚ด๋น„๊ฒŒ์ด์…˜ ๋ฐ”์—์„œ ํŠน์ • ์„น์…˜์œผ๋กœ ๊ฐ€๋Š” ๋ฒ„ํŠผ์„ ๋ˆ„๋ฅด๋ฉด ํ•ด๋‹น ์„น์…˜์œผ๋กœ ์‹œ์ฐจ๋ฅผ ๋‘๊ณ  ์Šค๋ฌด์Šคํ•˜๊ฒŒ ์ด๋™์‹œ์ผœ ์ฃผ๋Š” ํšจ๊ณผ๋ฅผ ๋งŒ๋“ค์–ด๋ณด๊ณ ์ž ํ•ฉ๋‹ˆ๋‹ค. ์ด๋ฒˆ ํŒจ๋Ÿด๋Ÿญ์Šค ์ดํŽ™ํŠธ 04 ํฌ์ŠคํŒ…์—์„œ๋Š” ์ง€๋‚œ ํŒจ๋Ÿด๋Ÿญ์Šค ์ดํŽ™ํŠธ 1, 2, 3๋ณด๋‹ค ๋”์šฑ ์ž์—ฐ์Šค๋Ÿฝ๊ณ  ์Šค๋ฌด์Šคํ•˜๊ฒŒ ์‚ฌ์ง„๊ณผ ๋ช…์–ธ์ด ๋“ฑ์žฅํ•˜๋„๋ก ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์ค˜ ๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. HTML ์†Œ์Šค header, parallax__dot(dot ๋‚ด๋น„๊ฒŒ์ด์…˜), main(parallax__cont(๋ช…์–ธ ๋ชจ์Œ)), aside(parallax__info(์Šคํฌ.. 2022. 9. 18.
[CSS] SVG๋ž€? - ๋„ํ˜•·์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐ SVG Animation ์Šค์ผ€์ผ๋Ÿฌ๋ธ” ๋ฒกํ„ฐ ๊ทธ๋ž˜ํ”ฝ์Šค(Scalable Vector Graphics, SVG)๋Š” 2์ฐจ์› ๋ฒกํ„ฐ ๊ทธ๋ž˜ํ”ฝ์„ ํ‘œํ˜„ํ•˜๊ธฐ ์œ„ํ•œ XML ๊ธฐ๋ฐ˜์˜ ํŒŒ์ผ ํ˜•์‹์œผ๋กœ, 1999๋…„ W3C(World Wide Web Consortium)์˜ ์ฃผ๋„ํ•˜์— ๊ฐœ๋ฐœ๋œ ์˜คํ”ˆ ํ‘œ์ค€์˜ ๋ฒกํ„ฐ ๊ทธ๋ž˜ํ”ฝ ํŒŒ์ผ ํ˜•์‹์ด๋‹ค. SVG ํ˜•์‹์˜ ์ด๋ฏธ์ง€์™€ ๊ทธ ์ž‘๋™์€ XML ํ…์ŠคํŠธ ํŒŒ์ผ๋“ค๋กœ ์ •์˜ ๋˜์–ด ๊ฒ€์ƒ‰ํ™”·๋ชฉ๋กํ™”·์Šคํฌ๋ฆฝํŠธํ™”๊ฐ€ ๊ฐ€๋Šฅํ•˜๋ฉฐ ํ•„์š”ํ•˜๋‹ค๋ฉด ์••์ถ•๋„ ๊ฐ€๋Šฅํ•˜๋‹ค. 01. ์ธํ„ฐ๋„ท ์ต์Šคํ”Œ๋กœ๋Ÿฌ9 ๋ฒ„์ „ ์ด์ƒ๋ถ€ํ„ฐ ์ง€์›๋ฉ๋‹ˆ๋‹ค. 02. XML์„ ์ด์šฉํ•˜์—ฌ ๋ผ์ธ, ๊ณก์„ , ๊ธฐํ•˜ํ•™์ ์ธ ๊ทธ๋ž˜ํ”ฝ ํ‘œํ˜„์ด ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค. 03. ๋ฒกํ„ฐ ๋ฐฉ์‹์ด๊ธฐ ๋•Œ๋ฌธ์— ํ™•๋Œ€ํ•˜๊ฑฐ๋‚˜ ์ถ•์†Œ๊ฐ€ ๊ฐ€๋Šฅํ•ฉ๋‹ˆ๋‹ค. 04. DOM ๋‹จ์œ„๋กœ ์ปจํŠธ๋กค์ด ๊ฐ€๋Šฅํ•˜์ง€๋งŒ ๋ฌธ์„œ ๋ณต์žก๋„๊ฐ€ ์ฆ๊ฐ€๋˜๋ฉด ๋ Œ๋”๋ง์ด ๋Š๋ ค์ง‘๋‹ˆ๋‹ค. ์‚ฌ๊ฐํ˜•.. 2022. 9. 7.
[CSS] ์• ๋‹ˆ๋ฉ”์ด์…˜ ์ข…๋ฅ˜์™€ ์‚ฌ์šฉ ๋ฐฉ๋ฒ• ์ด์ •๋ฆฌ CSS Animation CSS ์• ๋‹ˆ๋ฉ”์ด์…˜ ์ข…๋ฅ˜์™€ ์˜ˆ์‹œ ์ •๋ฆฌ. animation animation : name | duration | timing-function | delay | iteration | direction | fill-mode | play-state ์ข…๋ฅ˜ ์˜ˆ์‹œ animation-name @keyframe์— ์ง€์ •๋œ ์ด๋ฆ„์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. animation-duration ์• ๋‹ˆ๋ฉ”์ด์…˜์ด ์‹คํ–‰๋˜๋Š” ์‹œ๊ฐ„์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. animation-timing-function ์• ๋‹ˆ๋ฉ”์ด์…˜ ํ‚คํ”„๋ ˆ์ž„ ์›€์ง์ž„์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. animation-delay ์• ๋‹ˆ๋ฉ”์ด์…˜์ด ์‹œ์ž‘๋˜๊ธฐ ์ „๊นŒ์ง€ ์‹œ๊ฐ„์„ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. animation-iteration ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋ฐ˜๋ณต ํšŸ์ˆ˜๋ฅผ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. animation-derection ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋ฐฉํ–ฅ์„.. 2022. 9. 7.
[CSS] ๊ณต์ด ์ •์‹ ์—†์ด ํŠ€๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐ ๊ณต์ด ํŠ€๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐโšฝ ์ด๋ฒˆ ํฌ์ŠคํŒ…์—์„œ๋Š” ๊ณต์ด ์ •์‹ ์—†์ด๐Ÿคช๐Ÿคช๐Ÿคช ๋ฌดํ•œ์œผ๋กœ ํŠ€๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๋งŒ๋“ค์–ด๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. HTML ์ฝ”๋“œ CSS ์ฝ”๋“œ linear-gradient๋กœ ๊ทธ๋ผ๋””์–ธํŠธ ํšจ๊ณผ ๋ฐฐ๊ฒฝ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ position ์†์„ฑ๊ณผ animation, @keyframes ๋“ฑ์„ ์ž˜ ํ™œ์šฉํ•˜์—ฌ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์™„์„ฑ์‹œํ‚ฌ ์ˆ˜ ์žˆ๋‹ค. * { box-sizing: border-box; } body { background: linear-gradient(to top, #a18cd1 0%, #fbc2eb 100%); width: 100vw; height: 100vh; display: flex; justify-content: center; align-items: center; margin: 0; padding: 0; .. 2022. 9. 2.
[CSS] ์ •์‚ฌ๊ฐํ˜•์ด ํšŒ์ „ํ•˜๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐ ์ •์‚ฌ๊ฐํ˜•์ด ํšŒ์ „ํ•˜๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐโฌœ ์ด๋ฒˆ ํฌ์ŠคํŒ…์—์„œ๋Š” ์ •์‚ฌ๊ฐํ˜•์ด ์‹œ๊ณ„๋ฐฉํ–ฅ์œผ๋กœ ๊ณ„์† ๋Œ์•„๊ฐ€๋Š” ๊ฐ„๋‹จํ•œ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๋งŒ๋“ค์–ด๋ณด๋„๋ก ํ•˜๊ฒ ๋‹ค. HTML ์ฝ”๋“œ HTML ์ฝ”๋“œ๋Š” ๋งค์šฐ ๊ฐ„๋‹จํ•˜๋‹ค. box ํด๋ž˜์Šค๊ฐ’์„ ๊ฐ€์ง„ div๋งŒ ๋„ฃ๋Š”๋‹ค. CSS ์ฝ”๋“œ linear-gradient๋กœ ๊ทธ๋ผ๋””์–ธํŠธ ํšจ๊ณผ ๋ฐฐ๊ฒฝ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ position ์†์„ฑ๊ณผ animation, @keyframes ๋“ฑ์„ ์ž˜ ํ™œ์šฉํ•˜์—ฌ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์™„์„ฑ์‹œํ‚ฌ ์ˆ˜ ์žˆ๋‹ค. body { height: 100vh; background-image: linear-gradient(to top, goldenrod, darkkhaki) } .box { width: 50px; height: 50px; position: absolute; top: 0; left: 0; righ.. 2022. 8. 29.
[CSS] ์› 2๊ฐœ๊ฐ€ ์‹œ๊ณ„๋ฐฉํ–ฅ์œผ๋กœ ํšŒ์ „ํ•˜๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐ ์› 2๊ฐœ๊ฐ€ ๋Œ์•„๊ฐ€๋Š” ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋งŒ๋“ค๊ธฐโšช ์ด๋ฒˆ ํฌ์ŠคํŒ…์—์„œ๋Š” ๋™๊ทธ๋ผ๋ฏธ 2๊ฐœ๊ฐ€ ์‹œ๊ณ„๋ฐฉํ–ฅ์œผ๋กœ ๊ณ„์† ๋Œ์•„๊ฐ€๋Š” ๊ฐ„๋‹จํ•œ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ๋งŒ๋“ค์–ด๋ณด๋„๋ก ํ•˜๊ฒ ๋‹ค. HTML ์ฝ”๋“œ loading ํด๋ž˜์Šค๊ฐ’์„ ๊ฐ€์ง„ div ์•ˆ์— circle1, circle2 ํด๋ž˜์Šค๊ฐ’์„ ๊ฐ€์ง„ span ํƒœ๊ทธ 2๊ฐœ๋ฅผ ์ข…์†์‹œํ‚จ๋‹ค. CSS ์ฝ”๋“œ linear-gradient๋กœ ๊ทธ๋ผ๋””์–ธํŠธ ํšจ๊ณผ ๋ฐฐ๊ฒฝ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ position ์†์„ฑ๊ณผ animation, @keyframes ๋“ฑ์„ ์ž˜ ํ™œ์šฉํ•˜์—ฌ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์™„์„ฑ์‹œํ‚ฌ ์ˆ˜ ์žˆ๋‹ค. body { height: 100vh; background-image: linear-gradient(-60deg, darkorchid 0%, lightpink 100%); } .loading { position: absolute; lef.. 2022. 8. 29.
๋ฐ˜์‘ํ˜•

Reference Book

JavaScript
HTML
CSS
๊ด‘๊ณ  ์ค€๋น„์ค‘์ž…๋‹ˆ๋‹ค.