[CSS] ๋ฏธ๋””์–ด ์ฟผ๋ฆฌ, ๋ทฐํฌํŠธ

    1. ๋ฏธ๋””์–ด ์ฟผ๋ฆฌ [ ๊ธฐ๋ณธ ๋ฌธ๋ฒ• ] @media [only ๋˜๋Š” not][๋ฏธ๋””์–ด ์œ ํ˜•][and ๋˜๋Š” ,] (์กฐ๊ฑด๋ฌธ){์‹คํ–‰๋ฌธ} ๐Ÿ‘‰ and ๊ตฌ๋ฌธ ๋’ค ๊ณต๋ฐฑ ํ•„์ˆ˜! [ ์ ์šฉ ๋ฐฉ๋ฒ• ] [ min/max ] ํ•ด์ƒ๋„๋ณ„๋กœ ์›น์‚ฌ์ดํŠธ๋ฅผ ๋‹ค์–‘ํ•˜๊ฒŒ ํ‘œํ˜„ ๊ฐ€๋Šฅ min : ํฌ๊ธฐ๊ฐ€ ์ž‘์€ ์ˆœ์„œ๋Œ€๋กœ ์ž‘์„ฑ max : ํฌ๊ธฐ๊ฐ€ ํฐ ์ˆœ์„œ๋Œ€๋กœ ์ž‘์„ฑ ๋ฏธ๋””์–ด ์ฟผ๋ฆฌ๋กœ ํฌ๊ธฐ ๊ฐ์ง€ํ•  ๋•Œ๋Š” ๋ทฐํฌํŠธ ๊ธฐ์ค€์œผ๋กœ ๊ฐ์ง€ 2. ๋ทฐํฌํŠธ ํ™”๋ฉด์—์„œ ์‹ค์ œ ๋‚ด์šฉ์ด ํ‘œ์‹œ๋˜๋Š” ์˜์—ญ Desktop : ์„ค์ •ํ•œ ํ•ด์ƒ๋„ Device : ๊ธฐ๋ณธ์œผ๋กœ ์„ค์ •๋˜์–ด ์žˆ๋Š” ๊ฐ’ [ ์†์„ฑ ] width device-width, ์–‘์ˆ˜ ๋ทฐํฌํŠธ์˜ ๋„ˆ๋น„ height device-height, ์–‘์ˆ˜ ๋ทฐํฌํŠธ์˜ ๋†’์ด initial-scale ์–‘์ˆ˜ ๋ทฐํฌํŠธ์˜ ์ดˆ๊ธฐ ๋ฐฐ์œจ, ๊ธฐ๋ณธ๊ฐ’=1 user-scalable yes, ..

    [CSS] ๊ฐ€๋ณ€ ๊ทธ๋ฆฌ๋“œ, ๋งˆ์ง„, ํŒจ๋”ฉ, ํฐํŠธ

    [ ๊ณต์‹ ] (๊ฐ€๋ณ€ ํฌ๊ธฐ๋กœ ๋งŒ๋“ค ๋ฐ•์Šค์˜ ๊ฐ€๋กœ ๋„ˆ๋น„ / ๊ฐ€๋ณ€ ํฌ๊ธฐ๋กœ ๋งŒ๋“ค ๋ฐ•์Šค๋ฅผ ๊ฐ์‹ธ๊ณ  ์žˆ๋Š” ๋ฐ•์Šค์˜ ๊ฐ€๋กœ ๋„ˆ๋น„) * 100 = ๊ฐ€๋ณ€ ํฌ๊ธฐ์˜ % ๊ฐ’ ๐Ÿ‘‰ ๊ฐ€๋ณ€ ๊ทธ๋ฆฌ๋“œ, ๋งˆ์ง„, ํŒจ๋”ฉ์— ๋™์ผํ•˜๊ฒŒ ์ ์šฉ (๋‹จ, ํŒจ๋”ฉ์€ ์กฐ๊ฑด์— ๋”ฐ๋ผ ๋‹ค๋ฅด๊ฒŒ ์ ์šฉ) px๊ฐ’ ๊ธฐ์ค€์œผ๋กœ ๊ณ„์‚ฐํ•œ๋‹ค [ id = "wrap / wrapper" ] ๋ชจ๋“  ํƒœ๊ทธ๋ฅผ ๊ฐ์‹ธ๋Š” ๋ฐ•์Šค ์›น ๋ฌธ์„œ ๋‚ด์šฉ ์ „์ฒด์˜ ํฌ๊ธฐ๋‚˜ ๋ฐฐ๊ฒฝ์ƒ‰ ๋“ฑ ํ•œ๊บผ๋ฒˆ์— ์กฐ์ ˆ ๋ธŒ๋ผ์šฐ์ € ํ™”๋ฉด ํฌ๊ธฐ์— ์ƒ๊ด€์—†์ด ์›น ๋ฌธ์„œ์˜ ๋‚ด์šฉ ์ค‘์•™์— ๋ฐฐ์น˜ ๋ฐ˜์‘ํ˜• ์›น์—์„œ ์ž์‹ ๋ฐ•์Šค๋“ค์ด ๊ฐ€๋ณ€ ํฌ๊ธฐ๋กœ ์„ค์ •๋˜์—ˆ์„ ๋•Œ ๋ฌด์ œํ•œ์œผ๋กœ ๋Š˜์–ด๋‚˜๋Š” ๊ฒƒ ๋ฐฉ์ง€ ์ž์‹ ๋ฐ•์Šค๋“ค ๊ฐ€๋ณ€ ํฌ๊ธฐ๋กœ ๋งŒ๋“ค ๋•Œ ๊ธฐ์ค€ ํฌ๊ธฐ๋กœ ์‚ฌ์šฉ ๊ฐ€์žฅ ์ƒ์œ„์˜ ๋ฐ•์Šค -> ๊ฐ€๋ณ€ ๊ทธ๋ฆฌ๋“œ ๊ณ„์‚ฐ ์‹œ ๊ธฐ์ค€์ด ๋  ๋ฐ•์Šค ์—†์Œ [ ๊ฐ€๋ณ€ ํŒจ๋”ฉ ์ ์šฉ ๋ฐฉ๋ฒ• ] ๋ฐฉ๋ฒ• 1. ๊ธฐ๋ณธ ๋ฐฉ๋ฒ• (๊ฐ€๋ณ€ ํŒจ๋”ฉ์„ ์ ์šฉ..

    [CSS] ๋ฐ˜์‘ํ˜• ๋ฏธ๋””์–ด ์ฟผ๋ฆฌ

    /* Large desktop */ @media (min-width: 1500px) { ... } /* Portrait tablet to landscape and desktop */ @media (min-width: 768px) and (max-width: 979px) { ... } /* Landscape phone to portrait tablet */ @media (max-width: 767px) { ... } /* Landscape phones and down */ @media (max-width: 480px) { ... }

    [CSS] em, rem ๊ทธ๋ฆฌ๊ณ  css์˜ ๋‹จ์œ„๋“ค

    .selector { property: value; } Absolute length units : px Relative length units : em, rem, vw, vh, % 1. em - typography์—์„œ ํ˜„์žฌ ์ง€์ •๋œ point size ๋‚˜ํƒ€๋‚ด๋Š” ๋‹จ์œ„ / ํ˜„์žฌ ํฐํŠธ size ๋‚˜ํƒ€๋ƒ„ - ์„ ํƒ๋œ ํฐํŠธ์— ์ƒ๊ด€์—†์ด ํ•ญ์ƒ ๊ณ ์ •๋œ ํฐํŠธ ์‚ฌ์ด์ฆˆ ๊ฐ€์ง„๋‹ค - ๋ถ€๋ชจ์˜ ํฐํŠธ์‚ฌ์ด์ฆˆ์— ์ƒ๋Œ€์ ์œผ๋กœ ํฌ๊ธฐ๊ฐ€ ๊ณ„์‚ฐ๋œ๋‹ค - ๋ธŒ๋ผ์šฐ์ €์˜ ๊ธฐ๋ณธ ํฐํŠธ : 16px - ex) 8em = 16 * 8 = 128px = 800% 2. rem - root em - root์— ์ง€์ •๋œ ํฐํŠธ์‚ฌ์ด์ฆˆ์— ๋”ฐ๋ผ ํฌ๊ธฐ ๊ฒฐ์ • 3. vw, vh, wmin, wmax - ๋ถ€๋ชจ ์š”์†Œ์™€๋Š” ์ƒ๊ด€ ์—†๋‹ค, ๋ธŒ๋ผ์šฐ์ €์˜ ํฌ๊ธฐ์— ์˜์กด - 100vw : viewport ๋„ˆ..

    [CSS] position

    .container { position: static; position: relative; position: absolute; position: fixed; position: sticky; } top-left, top-right, bottom-left, bottom-right ๊ฐ’์œผ๋กœ position ๋ณ€๊ฒฝ ๊ฐ€๋Šฅ static : default value / html์— ์ •์˜๋œ ์ˆœ์„œ๋Œ€๋กœ ๋ธŒ๋ผ์šฐ์ €์ƒ์— ์ถœ๋ ฅ relative : left, right ๊ฐ’ ์ ์šฉ ๊ฐ€๋Šฅ / ์›๋ž˜ ์ž๋ฆฌ์—์„œ ์ƒ๋Œ€์ ์œผ๋กœ ๊ฐ’๋งŒํผ ์ด๋™ absolute : item์ด ๋‹ด๊ธด ๊ฐ€์žฅ ๊ฐ€๊นŒ์šด box ๋‚ด์—์„œ ์œ„์น˜ ๋ณ€๋™ fixed : window ๋‚ด์—์„œ ๋ณ€๋™ / ์›น ํŽ˜์ด์ง€ ๋‚ด์—์„œ ๋ณ€๋™ / box์™€๋Š” ๋ฌด๊ด€ sticky : ์›๋ž˜ ์žˆ๋˜ ์ž๋ฆฌ์— ์žˆ๋˜, scrollin..

    [Bootstrap] checkbox์™€ radio

    ๐Ÿ‘‰ ์ธ๋ผ์ธ ์ฒดํฌ๋ฐ•์Šค, ๋ผ๋””์˜ค - ์ฒดํฌ๋ฐ•์Šค๋‚˜ ๋ผ๋””์˜ค ์ปจํŠธ๋กค์„ ๊ฐ™์€ ์ค„์— ์ถœ๋ ฅ - ์ค„๋งˆ๋‹ค ๋„์šธ๋•Œ๋Š” ๋‹จ์ˆœ class="checkbox" ์ž‘์„ฑ 1 2 3 1 2 3

    [CSS] Flexbox

    float ๋ชฉ์  : ์ด๋ฏธ์ง€์™€ ํ…์ŠคํŠธ ์–ด๋–ป๊ฒŒ ๋ฐฐ์น˜ํ•  ๊ฒƒ์ธ์ง€ ์ •์˜ - left, center, right : ํ…์ŠคํŠธ๊ฐ€ ์ด๋ฏธ์ง€ ๊ฐ์‹ธ๋Š” ํ˜•ํƒœ๋กœ ๋‚˜ํƒ€๋‚จ flexbox 1. container์— ์ ์šฉ : display, flex-direction, flex-wrap, justifu-content, align-iems, ... 2. item์— ์ ์šฉ : order, flex-grow, flex, align-self, flex-shrink ์ค‘์‹ฌ์ถ•(main axis)๊ณผ ๋ฐ˜๋Œ€์ถ•(cross axis)์ด ์žˆ๋‹ค ์‹ค์Šต ์ค€๋น„ div.container>div.item.item${$}*10 ์ž…๋ ฅ ํ›„ tabํ‚ค ๋ˆ„๋ฅด๊ธฐ Tip height: 100% → ์•„์ดํ…œ์— ๋งž๊ฒŒ ๋†’์ด๊ฐ€ ์ง€์ •๋จ, ์•„์ดํ…œ์ด ๋“ค์–ด์žˆ๋Š” ๋ถ€๋ชจ์˜ ๋†’์ด์— 100% ์ฑ„์šฐ๊ฒ ๋‹ค ์˜ˆ๋ฅผ ๋“ค๋ฉด..

    [CSS] Flex Container

    display: flex; ์ฃผ์ถ• ๋ฐฉํ–ฅ ์ •๋ ฌ(๊ฐ€๋กœ์ถ•) justify-content: center; justify-content: flex-end; ๊ต์ฐจ์ถ• ๋ฐฉํ–ฅ ์ •๋ ฌ(์„ธ๋กœ์ถ•) align-items: center; align-items: flex-end;