17_Sep_2021 ๐Ÿฐ์—˜๋ฆฌ์Šค AI ํŠธ๋ž™ TIL: ๋ฐ˜์‘ํ˜• ์›นํŽ˜์ด์ง€ ์ œ์ž‘ ์‹ค์Šต

์œ ํ™˜์ตยท2021๋…„ 9์›” 17์ผ
1

Alexander Yoo์˜ Web Programming

๋ชฉ๋ก ๋ณด๊ธฐ
2/4

2์ฐจ์› 3์ฐจ์› ์š”์†Œ๋ฅผ ๊ฒฐ์ •ํ•˜๋Š” CSS ์†์„ฑ: position

ํ˜„์‹ค์— ์กด์žฌํ•˜๋Š” ์ฐจ์›๋“ค:

  • first-dimension: the world of linear- elements
  • second-dimension: the world of plane-elements
  • third-dimension: the world of space-elements

์›น์‚ฌ์ดํŠธ์˜ ๊ฒฝ์šฐ, 2์ฐจ์›๊ณผ 3์ฐจ์›์„ ๊ฒฐํ•ฉํ•˜์—ฌ ๋งŒ๋“  ๊ฒƒ์ด๋‹ค.

2์ฐจ์›๊ณผ 3์ฐจ์›์˜ ์ฐจ์ด

์›น์—์„œ์˜ 3์ฐจ์› ์š”์†Œ๋ž€?: ๊ฐ ์š”์†Œ ๊ฐ„ ๋ ˆ์ด์–ด๊ฐ€ ์žˆ๋Š” ํ˜•ํƒœ
(์š”์†Œ์˜ ๋ฐฐ์น˜๊ฐ€ ๊ณ‚์ ธ์žˆ๋Š” ๋ชจ์Šต)

์›น์˜ ์š”์†Œ๋ฅผ 2์ฐจ์› ํ˜น์€ 3์ฐจ์›์œผ๋กœ ๊ตฌ๋ถ„ํ•˜๋ ค๋ฉด ์„ธ ๊ฐ€์ง€๋ฅผ ๊ณ ๋ คํ•  ์ˆ˜ ์žˆ๋‹ค.

  • ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ์ด ์ผ์–ด๋‚˜๋Š” ๊ฐ€? (second)
  • top, left, right, bottom ์†์„ฑ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” ๊ฐ€? (third)
  • ์ž์‹์˜ ๋†’์ด ๊ฐ’์ด ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ์„ ์ฃผ๋Š” ๊ฐ€? (second)

์›น์— ์กด์žฌํ•˜๋Š” ๊ฐ ์ฐจ์›์˜ ์š”์†Œ (position ์†์„ฑ๊ฐ’):

2์ฐจ์› ์š”์†Œ

  • static: ๋ถ€๋ชจ ์ž์‹ ๊ฐ„ ๋ฐœ์ƒํ•˜๋Š” ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ์ด ๋ฐœ์ƒํ•˜๊ณ , (๋ถ€๋ชจ๊ฐ€ ๋†’์ด๊ฐ’์„ ๊ฐ€์ง€๊ณ  ์žˆ์ง€ ์•Š์„ ๊ฒฝ์šฐ) ์ž์‹์˜ ๋†’์ด๊ฐ’์ด ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ์„ ์ค€๋‹ค.

2 || 3์ฐจ์› ์š”์†Œ

  • relative: ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ์ด ๋ฐœ์ƒํ•˜๊ณ , top, left, right bottom CSS ์†์„ฑ ์‚ฌ์šฉ ๊ฐ€๋Šฅ

3์ฐจ์› ์š”์†Œ

  • absolute: (top~bottm ์†์„ฑ ์‚ฌ์šฉ ๊ฐ€๋Šฅ)
  • fixed: (top~bottm ์†์„ฑ ์‚ฌ์šฉ ๊ฐ€๋Šฅ)

์ฝ”๋“œ ์˜ˆ

  <style>        
      .static_p {
          width: 300px;
          /* ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์ด ์—†์œผ๋ฉด ์ž์‹์˜ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ์„ ๋ฐ›์Œ. ๊ฐ™์ด ์œ„์น˜*/
          /* height: 300px; */
          background-color: yellow;
      }
        /* ์ž์‹์š”์†Œ์˜ ๋งˆ์ง„ ๊ฐ’์„ ์กฐ์ ˆํ•˜๋ฉด,
        ๋ถ€๋ชจ์š”์†Œ๊ฐ€ position ๊ฐ’์ด ์—†์„ ๊ฒฝ์šฐ ๊ฐ™์ด ์˜ํ–ฅ์„ ์ค€๋‹ค.*/
      .static_c {
          /* ๋ช…์‹œ์ ์œผ๋กœ ์„ค์ •์„ ํ•˜์ง€ ์•Š์•„๋„, ์ž์‹์š”์†Œ position: static 
          (๋ชจ๋“  html ์š”์†Œ๋“ค์€ default ๊ฐ’์œผ๋กœ position: static */
          /* position: static; */
          width: 100px;
          height: 100px;
          background-color: blue;
          /* margin-top: 100px; */
          /* top: 100px; 2์ฐจ์› ์š”์†Œ์ด๋ฏ€๋กœ ์ ์šฉ ์•ˆ๋จ. */
      }
   </style>

static: default value, margin ๋ณ‘ํ•ฉ ํ˜„์ƒ O, ์ž์‹์˜ ๋†’์ด๊ฐ’์ด ๋ถ€๋ชจ์˜ ๋…ธ๋†’์ด๊ฐ’์— ์˜ํ–ฅ O

<style>
      .fixed_p {
          width: 300px;
          /* height: 300px; 
          ๋ถ€๋ชจ์˜ height๋ฅผ ์„ค์ •ํ•˜์ง€ ์•Š์„ ๊ฒฝ์šฐ, 
          ๋ถ€๋ชจ ์š”์†Œ ์‚ฌ๋ผ์ง ์ž์‹์˜ ์†์„ฑ๊ฐ’์ด ๋ถ€๋ชจ์— ์˜ํ–ฅ์„ ์ฃผ์ง€ ๋ชปํ•œ๋‹ค.*/
          background-color: yellow;
      }

      .fixed_c {
          position: fixed; /*ํ™”๋ฉด์ด ์›€์ง์ด๋ฉด ํ™”๋ฉด๊ณผ ๊ฐ™์ด ์›€์ง์ž„*/
          width: 100px;
          height: 100px;
          background-color: blue;
          margin-top: 100px; /* fixed ์ ์šฉ ์‹œ, 
         ์ž์‹ ์š”์†Œ๋งŒ ์•„๋ž˜๋กœ 100px์ด๋™, ๋ถ€๋ชจ์—๋Š” ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ X */
          top: 100px; 
          /*fixed ์ ์šฉ ์‹œ, ์ตœ์ดˆ ์œ„์น˜์—์„œ 
          ๋ธŒ๋ผ์šฐ์ € ์ตœ์ƒ๋‹จ ๊ธฐ์ค€์œผ๋กœ ๋ฐ‘์œผ๋กœ 100px ์ด๋™:
          top~bottom ์†์„ฑ ์ ์šฉ ๊ฐ€๋Šฅ*/
      }
</style>

fixed: margin ๋ณ‘ํ•ฉ ํ˜„์ƒ X, top~bottom ์ ์šฉ๊ฐ€๋Šฅ, ์ž์‹์˜ ๋†’์ด๊ฐ’์ด ๋ถ€๋ชจ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ X (3์ฐจ์› ์š”์†Œ ํŠน์ง•)

<style>
      .relative_p {
          width: 300px;
          /* ์ž์‹์˜ ๋†’์ด๊ฐ’๋งŒํผ ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์ด ๋ณ€๊ฒฝ. ๋ถ€๋ชจ๊ฐ’์— ์˜ํ–ฅ.  */
          /* height: 300px; */ 
          background-color: yellow;
      }

      .relative_c {
          position: relative;
          width: 100px;
          height: 100px;
          background-color: blue;
          
          /* ๋ถ€๋ชจํƒœ๊ทธ๋„ ์ž์‹ํƒœ๊ทธ์™€ ๊ฐ™์ด ์›€์ง์ž„. ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ O */
          margin-top: 100px;
          
          /* ์ž์‹์š”์†Œ๊ฐ€ ์ตœ์ดˆ ์œ„์น˜ ๊ธฐ์ค€์œผ๋กœ 100px ๋งŒํผ ์ด๋™. top~bottom ์†์„ฑ ์ ์šฉ ๊ฐ€๋Šฅ*/
          top: 100px;
      }
</style>

relative: margin ๋ณ‘ํ•ฉ ํ˜„์ƒ O, top~bottom ์†์„ฑ ์ ์šฉ ๊ฐ€๋Šฅ, ์ž์‹์˜ ๋†’์ด๊ฐ’์ด ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ

<style>
	  .absolute_p {
          position: relative;
          width: 300px;
          /* ์ž์‹์˜ ๋†’์ด๊ฐ’์ด ๋ถ€๋ชจ์˜ ๋†’์ด๊ฐ’์— ์˜ํ–ฅ X*/
          height: 300px;
          background-color: yellow;
      }

      .absolute_c {
          position: absolute;
          width: 100px;
          height: 100px;
          background-color: blue;
          margin-top: 100px; 
/*๋ถ€๋ชจ ์š”์†Œ๋Š” ์ด๋™ํ•˜์ง€ ์•Š๊ณ  ์ž์‹๋งŒ ์ด๋™: ๋งˆ์ง„ ๋ณ‘ํ•ฉ ํ˜„์ƒ X*/  
         top: 100px; 
 /*์ž์‹์š”์†Œ๊ฐ€ ๋ธŒ๋ผ์šฐ์ € ์ตœ์ƒ๋‹จ ๊ธฐ์ค€์œผ๋กœ 100px ๋งŒํผ ์•„๋ž˜๋กœ ์ด๋™: 
 top~bottom ์ ์šฉ ๋ถˆ๊ฐ€(๋ถ€๋ชจ๊ฐ€ static์ผ ๊ฒฝ์šฐ) 
 ๊ทธ๋Ÿฌ๋‚˜, top~bottom ์ ์šฉ ๊ฐ€๋Šฅํ•œ ๊ฒฝ์šฐ๋Š” 
 (๋ถ€๋ชจ๊ฐ€ relative์ผ ๊ฒฝ์šฐ) 
 ๋ถ€๋ชจ์˜ position ์ƒํƒœ์— ๋”ฐ๋ผ ์ขŒํ‘œ ๊ธฐ์ค€์ ์ด ๋‹ฌ๋ผ์ง.*/
      }
      
</style>

z-์ถ•์— ์˜ํ–ฅ์„ ๋ฏธ์น˜๋Š” CSS ์†์„ฑ

z-์ถ•์ด๋ž€?

์–ด๋–ค ์š”์†Œ๊ฐ€ ๋” ์•ž์œผ๋กœ ๋‚˜์™€์žˆ๋Š” ์ง€ ์„ค์ •ํ•˜๋Š” ์†์„ฑ์ด๋‹ค. ์ฆ‰, 3์ฐจ์›์ธ ๋ ˆ์ด์–ด์ธต์„ ๋งŒ๋“ ๋‹ค๋Š” ์˜๋ฏธ์ด๊ธฐ๋„ ํ•˜๋‹ค. ์ฆ‰, position์ด 3์ฐจ์›์ผ ๊ฒฝ์šฐ(absolute์™€ fixed, ๊ทธ๋ฆฌ๊ณ  relative)์—๋งŒ ์ ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

  <style>

    .z-index-1 {
        position: absolute;
        width: 100%;
        height: 300px;
        /* ํŒŒ๋ž€์ƒ‰ ๋ถ€๋ถ„์˜ ์•ž์— ์œ„์น˜ํ•จ: 
        ๋ ˆ์ด์–ด ์ธต์ด ๊ฒน์น˜๊ฒŒ ๋œ๋‹ค.*/
        background-color: yellow;
        /*ํŒŒ๋ž€์ƒ‰ ๋ฐ•์Šค์˜ ์œ„๋กœ ์œ„์น˜ํ•˜๊ฒŒ ํ•˜๊ณ  ์‹ถ๋‹ค๋ฉด?*/
        z-index: 100; /* ๋‹จ์œ„ ์ƒ๋žต*/
    }

    .z-index-2 {
        position: absolute;
        width: 100%;
        height: 200px;
        /*๋…ธ๋ž€์ƒ‰ ๋ถ€๋ถ„์˜ ์•ž์— ์œ„์น˜ํ•จ: 
        ๋‚˜์ค‘์— absolute๊ฐ€ ์ž‘์„ฑ๋œ z์ถ•์˜ ์šฐ์„ ์ˆœ์œ„๊ฐ€ ๋” ๋†’๋‹ค๋Š” ๊ฑธ ์•Œ ์ˆ˜ ์žˆ๋‹ค.*/
        background-color: blue;
        z-index: 50px;
        /* ๋…ธ๋ž€์ƒ‰ ๋ถ€๋ถ„์˜ z-index ๊ฐ’์ด ๋” ํผ. ์šฐ์„ ์ˆœ์œ„๋ฅผ ์ •ํ•œ๋‹ค. */
        
    }

  </style>

background-attachment

์ด๊ฒƒ์€ ์›น์‚ฌ์ดํŠธ๋ฅผ ๋งŒ๋“ค ๋•Œ ์•Œ์•„๋‘๋ฉด ์ข‹์„ ํŒ์ด๋‹ค.

  • background-size: ๋ฐฐ๊ฒฝ ์ด๋ฏธ์ง€์˜ ํฌ๊ธฐ๋ฅผ ์ •ํ•œ๋‹ค. (์†์„ฑ๊ฐ’: contain, cover)
    contain: ๊ณต๊ฐ„์„ ๋ฒ—์–ด๋‚˜์ง€ ์•Š๋Š” ์ตœ๋Œ€์˜ ํฌ๊ธฐ๋กœ ํ™•๋Œ€ ํ˜น์€ ์ถ•์†Œ
    (์ด๋ฏธ์ง€๋ฅผ ์˜จ์ „ํ•˜๊ฒŒ ๋„ฃ์œผ๋ผ๋Š” ์˜๋ฏธ, ๊ฐ€๋กœ์„ธ๋กœ ๋น„์œจ์€ ์œ ์ง€๊ฐ€ ๋จ)
    cover: ๊ณต๊ฐ„์„ ๋ฒ—์–ด๋‚˜๋„ ๊ฝ‰ ์ฑ„์›Œ์„œ ํ™•๋Œ€ํ•˜๊ฑฐ๋‚˜ ์ถ•์†Œ
    (๊ฐ€๋กœ์„ธ๋กœ ๋น„์œจ์ด ์œ ์ง€๋œ๋‹ค. ๋ณดํ†ต์˜ ๊ฒฝ์šฐ, ์ด ์†์„ฑ๊ฐ’์„ ๋งŽ์ด ์‚ฌ์šฉํ•œ๋‹ค.
  • background-attachment: ๋ฐฐ๊ฒฝ ์ด๋ฏธ์ง€์˜ ์Šคํฌ๋กค ์—ฌ๋ถ€๋ฅผ ๊ฒฐ์ •
    scroll: ๋‚ด์šฉ์„ ์Šคํฌ๋กค ๋˜๋„ ๋ฐฐ๊ฒฝ ์ด๋ฏธ์ง€๋Š” absolute.
    fixed: ๋ฐฐ๊ฒฝ ์ด๋ฏธ์ง€๋Š” fixed, ์•ˆ์— ์žˆ๋Š” ๋‚ด์šฉ๋ฌผ๋งŒ ์Šคํฌ๋กค ๋จ.

์ฝ”๋“œ ์˜ˆ

<style>

    .bgSize {
        width: 400px;
        height: 400px;
        background: yellow url("img/intro/1.png") center no-repeat;
        background-size: cover;
        /*cover: ํ™”๋ฉด์„ ์ „๋ถ€ ๋ฎ์Œ.
          contain: ์ด๋ฏธ์ง€๊ฐ€ ํ™”๋ฉด์„ ๋„˜์–ด๊ฐ€์ง€ ์•Š๊ฒŒ ์ฑ„์›€*/
    }
    
    body {
      background: url("img/main/player1.png") no-repeat;
      background-attachment: fixed;
      /* fixed: ๋ฐฐ๊ฒฝ์€ fixed. ๋‚ด์šฉ์€ ์Šคํฌ๋กค */
      /* scroll: ๋ฐฐ๊ฒฝ๊ณผ ๋‚ด์šฉ์ด ๊ฐ™์ด ์Šคํฌ๋กค ๋œ๋‹ค. */
    }

  </style>

y์ถ• ์ค‘์•™ ์ •๋ ฌ

์›น์‚ฌ์ดํŠธ ์ •๋ ฌ ์ž‘์—…์„ ํ•  ๋•Œ, x์ถ•์ด๋‚˜ y์ถ•์„ ์ค‘์•™ ์ •๋ ฌํ•  ๊ฒฝ์šฐ๊ฐ€ ๋งŽ๋‹ค.

<style>
element {
top: 45%; 
/* top์—์„œ 45%๋งŒํผ ๋‚ด๋ฆผ*/
transform: translateY(-50);
/* y์ถ•์œผ๋กœ ์š”์†Œ์˜ ํฌ๊ธฐ๋ฅผ ๊ธฐ์ค€์œผ๋กœ ๋ช‡% ํ˜น์€ ๋ช‡ px๋งŒํผ ์›€์ง์ด๊ฒ ๋‹ค.*/
}
</style>

์œ„์˜ ๋‘ ๊ฐ€์ง€ ์†์„ฑ์„ ์‚ฌ์šฉํ•˜์—ฌ ์ ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.
top~bottom ์†์„ฑ์„ ์ ์šฉํ•  ์ˆ˜ ์žˆ๋Š” 3์ฐจ์› ์š”์†Œ์—๋งŒ(absolute, fixed, relative) ์ด ์†์„ฑ์„ >์ ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

์ฃผ์˜์ : ํฌ๋กฌ ๋ธŒ๋ผ์šฐ์ € ํ•˜์œ„ ๋ฒ„์ „(v.7,v.8)์ผ ๊ฒฝ์šฐ, ์ ์šฉ์ด ์•ˆ๋  ์ˆ˜๋„ ์žˆ์Œ

Full Clip ํ”Œ๋Ÿฌ๊ทธ ์ธ: ๋ฐฐ๊ฒฝ ์Šฌ๋ผ์ด๋“œ ์ ์šฉํ•˜๊ธฐ

<script src='๊ฒฝ๋กœ/full clip.js'></script>
๋ฐฐ๊ฒฝ์ด๋ฏธ์ง€๊ฐ€ ์ž๋™์œผ๋กœ ๋กค๋ง๋˜๋Š” ํšจ๊ณผ๋ฅผ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ๋‹ค.
์šฉ๋Ÿ‰์ด ์ž‘์•„, ์›น์‚ฌ์ดํŠธ ๋กœ๋”ฉ ์†๋„ ๋ถ€๋‹ด์„ ๋œ ์ˆ˜ ์žˆ๋‹ค.

full-clip ์ œ๊ณต ๊ณต์‹ ๊นƒํ—™ ์‚ฌ์ดํŠธ

๋‹จ, ์ด ์ฝ”๋“œ๋ฅผ ์ž…๋ ฅํ•˜๊ธฐ ์ „, JQueryํŒŒ์ผ์ด ์—ฐ๋™๋˜์–ด ์žˆ์–ด์•ผ ํ•œ๋‹ค.

์•„๋ž˜์˜ ์ฝ”๋“œ๋ฅผ ์••๋ ฅํ•˜์—ฌ, JQuery ๋ฐ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ์™€ ์—ฐ๋™ํ•œ๋‹ค.

<script>
  $('.fullBg').fullClip 
  ({
  	images: [
  		'images/house.jpg',
  		'images/road.jpg',
  		'images/winter.jpg'
  	],
  	transitionTime: 1000,
  	wait: 7000
  });
 </script>

ํŠน์ •ํ•œ ์š”์†Œ์— fullClip ๋ฉ”์„œ๋“œ์˜ ์ธ์ž๋กœ ๋กค๋งํ•  ์ด๋ฏธ์ง€ ๊ฐœ์ฒด๋“ค์˜ ๊ฒฝ๋กœ๋ฅผ ๋„˜๊ฒจ์ค€๋‹ค. ์ด๋ฏธ์ง€ ์ „ํ™˜ ์‹œ๊ฐ„๋„ ์„ค์ •ํ•˜๊ณ , ๋Œ€๊ธฐ ์‹œ๊ฐ„ ๋˜ํ•œ ์ง€์ •ํ•œ๋‹ค.

<style>
fullBg {
	background-position: center center;
    background-attachment: fixed;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
</style>

์œ„์˜ CSS style์„ ์ ์šฉํ•˜๋Š” ๊ฒƒ๋„ ์žŠ์ง€ ๋ง์•„์•ผ ํ•œ๋‹ค.

๋ณธ๊ฒฉ์ ์œผ๋กœ ์›น ์‚ฌ์ดํŠธ๋ฅผ ์ œ์ž‘ํ•˜๊ธฐ ์ „, Default CSS๋ฅผ ์ ์šฉํ•˜์—ฌ ์†์„ฑ์„ ์ดˆ๊ธฐํ™” ํ•˜๋Š” ๊ฒƒ์ด ์ข‹๋‹ค.

/*Default CSS*/
<style>
* {
    margin: 0;
    padding: 0;
    
    box-sizing: border-box;
    /*๊ณต๊ฐ„์˜ ํฌ๊ธฐ๋Š” ๊ทธ๋Œ€๋กœ ์œ ์ง€๊ฐ€ ๋˜์ง€๋งŒ, ํŒจ๋”ฉ ๊ฐ’๋งŒ ์ ์šฉ์ด ๋œ๋‹ค.*/
}
</style>

๋งŒ๋“  ํŽ˜์ด์ง€๊ฐ€ ๋ชจ๋ฐ”์ผ์—์„œ๋„ ๋ฐ˜์‘ํ˜• ์›น ๋ ˆ์ด์•„์›ƒ์œผ๋กœ ์ž˜ ๋™์ž‘ํ•˜๋Š” ์ง€ ํ™•์ธํ•˜๊ธฐ ์œ„ํ•ด์„  ํฌ๋กฌ ๋ธŒ๋ผ์šฐ์ €๋ฅผ ๊ธฐ์ค€์œผ๋กœ ๊ฒฐ๊ณผ๋ฌผ์„ ์„œ๋ฒ„์— ๋“ฑ๋กํ•˜์—ฌ ์›ํ•˜๋Š” ๊ธฐ๊ธฐ๋กœ ๋„๋ฉ”์ธ ์ฃผ์†Œ๋ฅผ ์ž…๋ ฅํ•˜์—ฌ ํ™•์ธํ•˜๋Š” ๊ฒƒ์ด ๊ฐ€์žฅ ์ •ํ™•ํ•˜๋‹ค.

๊ทธ๋Ÿฌ๋‚˜, ๋งค๋ฒˆ ๊ทธ๋ ‡๊ฒŒ ํ™•์ธํ•˜๋Š” ๊ฒƒ์€ ๋ฒˆ๊ฑฐ๋กœ์šฐ๋ฏ€๋กœ, ๊ฐœ๋ฐœ์ž ๋„๊ตฌ์˜ ์™ผ์ชฝ ์œ„ ๋ ๋ชจ๋ฐ”์ผ ํ™”๋ฉด ์ฒดํฌ ๋ฒ„ํŠผ์„ ํ™œ์šฉํ•  ์ˆ˜๋„ ์žˆ๋‹ค.

Continuing on the next post...

profile
์‚ฌ์šฉ์ž์˜ ํŽธ์˜๋ฅผ ๋” ์ƒ๊ฐํ•˜๊ณ  ํŽธ์•ˆํ•œ UI/UX ๊ฐœ๋ฐœ์„ ๊ฟˆ๊พธ๋Š” ํ”„๋ก ํŠธ์—”๋“œ ๊ฐœ๋ฐœ์ž ์ง€๋ง์ƒ์ž…๋‹ˆ๋‹ค.

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