본문 바로가기

HTML & CSS & JavaScript/CSS

flex 스타일 3

  • item 전용 속성
    - order : item의 순서를 지정하는 속성
<div class="flex-container">
        <div class="item item1 order1">item1</div>
        <div class="item item2 order2">item2</div>
        <div class="item item3 order3">item3</div>
        <div class="item item4 order4">item4</div>
        <div class="item item5 order5">item5</div>
</div>
.flex-container{
    height: 400px;
    background-color: #ddd;
    display: flex;
}

/* ************** */
/*      order     */
/* ************** */

/* flex-container 내부 item의 순서를 지정하는 속성
   (기본값 0, 정수, 양수/음수 가능)
*/

.order1{order: 5}
.order2{order: 3}
.order3{order: 4}
.order4{order: 2}
.order5{order: 1}


  • flex-grow(팽창)
    - item이 flex-container 내부에서 비어있는 공간을 매꿀 수 있도록 팽창하는 정도를 지정하는 속성
    <div class="flex-container">
        <div class="item item1 grow1">item1</div>
        <div class="item item2 grow2">item2</div>
        <div class="item item3 grow3">item3</div>
        <div class="item item4 grow4">item4</div>
    </div>
/* ************* */
/*   flex-grow   */
/* ************* */
/* item이 flex-container 내부에서 비어있는 공간을
   매꿀 수 있도록 팽창하는 정도를 지정하는 속성
   -> 지정된 비율에 맞게 팽창
   (기본값 0 -> 팽창 X)
*/
.grow1{flex-grow: 1;}
.grow2{flex-grow: 2;}
.grow3{flex-grow: 3;}
.grow4{flex-grow: 4;}

기본값 - grow 미적용
grow 적용


  • flex-shrink(수축)
    - item이 수축하는 정도를 지정하는 속성
    <div class="flex-container">
        <div class="item item1 shrink0">item1</div>
        <div class="item item2 shrink1">item2</div>
        <div class="item item3 shrink2">item3</div>
        <div class="item item4 shrink3">item4</div>
    </div>
/* *************** */
/*   flex-shrink   */
/* *************** */
/* item이 수축하는 정도를 지정하는 속성 (기본값 1) */
.shrink0{flex-shrink: 0;}
.shrink1{flex-shrink: 1;}
.shrink2{flex-shrink: 2;}
.shrink3{flex-shrink: 3;}


  • flex-basis
    - item의 main axis 방향으로의 기본 점유율(크기)을 지정하는 속성
     (각종 크기 단위 px, %, vh, em, rem 등 사용 가능)
    <div class="flex-container">
        <div class="item item1 basis-150px">item1</div>
        <div class="item item2 basis-10">item2</div>
        <div class="item item3 basis-25">item3</div>
        <div class="item item4 flex1">item4</div>
    </div>
/* *************** */
/*   flex-basis   */
/* *************** */
/* item의 main axis 방향으로의
   기본 점유율(크기)을 지정하는 속성
   (각종 크기 단위 사용 가능)
*/
.basis-150px{flex-basis: 150px;}
.basis-10{flex-basis: 10%;}
.basis-25{flex-basis: 25%;}
.basis-50{flex-basis: 50%;}


  • flex
    - flex-grow, flex-shrink, flex-basis 3개를 합쳐둔 속성
    <div class="flex-container">
        <div class="item item1 basis-150px">item1</div>
        <div class="item item2 basis-10">item2</div>
        <div class="item item3 basis-25">item3</div>
        <!-- <div class="item item4 basis-50">item4</div> -->
        <div class="item item4 flex1">item4</div>
    </div>
/* ****** */
/* flex */
/* ***** */
/* flex-grow, flex-shrink, flex-basis 3개를 합쳐둔 속성 */
.flex1{flex: 0 0 100px;}


  • align-self
    - 각각의 item별로 cross axis 방향으로의 정렬을 지정하는 속성
    <div class="flex-container">
        <div class="item item1 self-start">item1</div>
        <div class="item item2 self-end">item2</div>
        <div class="item item3 self-center">item3</div>
    </div>
/* ********** */
/* align-self */
/* ********** */
/* 각각의 item 별로 cross axis 방향으로 정렬을 지정하는 속성 */
.self-start{align-self: flex-start;}
.self-end{align-self: flex-end;}
.self-center{align-self: center;}

 

'HTML & CSS & JavaScript > CSS' 카테고리의 다른 글

글꼴 폰트 관련 스타일  (2) 2024.12.14
글자 관련 스타일  (1) 2024.12.14
flex 스타일 2  (0) 2024.12.14
flex 스타일 1  (0) 2024.12.14
레이아웃 스타일4  (0) 2024.12.14