Float 의미와 문제점

최현호·2022년 4월 4일
0

CSS

목록 보기
7/15
post-thumbnail
post-custom-banner

Float

grid, flex와 마찬가지로 요소를 배치하기 위한 속성 입니다.

float 라는 단어는 원래 ‘뜨다’ 라는 의미이며, block 요소들을 가로 배치하기 위해 사용 합니다.

하지만 무작정 사용하면 많은 문제가 생길 수 있습니다.


float를 사용하면 문제점 ?

  1. 부모가 가지고 있던 자식이 float가 되버리면 집 나간 자식이 되버립니다.

    • 부모의 height를 선언하지 않을 경우, 자식요소의 height 의 합 = 부모의 height

    • 나간 자식의 자리를 빈 공간(붕 뜨게 된다)으로 인지하여 공간을 채우기 위해 이동 합니다. -> 부모의 height가 줄어듭니다.

<div class="parent">
    <div class="child red">child</div>
    <div class="child yellow">child</div>
    <div class="child blue">child</div>
</div>
*{
    box-sizing: border-box;
    margin: 0;  
}

.parent{
    width: 200px;
    margin: 0 auto;
    background-color: #eff2f7;
}

.child{
    width: 200px;
    height: 200px;
    text-align: center;
    color: #fff;
    font-weight: 600;
    font-size: 60px;
}

.red{
    background-color: red;
    float: left;
}

.yellow{
    background-color: yellow;
    
}

.blue{
    background-color: blue;
}

bandicam 2022-03-17 22-21-48-335
bandicam 2022-03-17 22-22-11-907

  • 첫 번째는 float 를 사용하기 전

  • 두 번째는 red 에게 float : left 선언

  • redparent 라는 부모를 가지고 있었는데 float를 선언함 과 동시에 집 나간 자식이 되어 버렸고 즉 요소가 붕 떠있는 상태이고,
    뒤에 자식들은 앞선 red의 자리를 빈공간으로 인식하고 자리가 비워져있어 앞으로 채워진다. -> 따라서 부모의 height 또한 변합니다.


  1. block 으로 신분 상승
  • inline,inline-block,block 요소들에게 float 를 사용하면 -> block 으로 속성이 바뀝니다.

  • 즉, float가 선언된 요소에게 block 의 display 값을 가지게 되므로 -> margin, width,height 값 등을 사용 할 수 있습니다.


  1. block 요소가 되지만 길막을 하지는 못합니다.
  • 기본적으로 width를 선언하지 않은 경우, width = 부모의 content-box의 100% 를 가지게 됩니다.

  • 하지만, float가 되면 그렇지 않습니다.

  • 위의 코드에서 width 값만 지웠습니다.

.child{
    height: 200px;
    text-align: center;
    color: #fff;
    font-weight: 600;
    font-size: 60px;
}

bandicam 2022-03-17 22-39-10-741

  • float를 하면 실제 content가 가진 크기 만큼 붕 뜨게 됩니다.
  • 하지만 block 이지만, 옆에 다른 요소가 오지 못하게 할 수는 없습니다.

  1. float는 요소는 inline 만 찾을 수 있습니다.
  • block 요소들은 float 를 없는 걸로 취급을 합니다. 하지만 inline의 성격을 가진 것은 float의 존재를 기억 합니다.
<div class="parent">
    <div class="child red">child</div>
    <div class="child yellow">child</div>
    <div class="child blue">child</div>
</div>
<div class="other">
    더미 text
</div>
.child{
    width: 200px;
    height: 200px;
    text-align: center;
    color: #fff;
    font-weight: 600;
    float: left;
}

bandicam 2022-03-17 23-04-10-878

  • 가장 먼저 설명한 "나간 자식의 자리를 빈 공간(붕 뜨게 된다)으로 인지하여 공간을 채우기 위해 이동 합니다. -> 부모의 height가 줄어듭니다."

  • 현재 other 앞에 있는 parentheight가 0 입니다. -> parent 의 자식인 child 에게 float를 선언했기 때문

  • 그럼 other 는 빈 공간이 되기 때문에 올라가는 것은 자연스러운 현상 입니다.

  • 하지만 other 안에 있는 text 들은 레이아웃이 깨져버립니다.

  • 다시 한번 blue에게 margin-right : 300px 을 주겠습니다.

bandicam 2022-03-17 23-13-04-795

  • 이처럼 block 요소들은 찾을 수 없지만 text나 img 같은 lnline의 성격을 가진 속성들은 float의 존재를 찾을 수 있어서 레이아웃에 영향을 받습니다.

참고

profile
현재 블로그 : https://choi-hyunho.com/
post-custom-banner

0개의 댓글