찾다
웹 프론트엔드CSS 튜토리얼Flexbox 행이 남은 수직 공간을 채우는 방법은 무엇입니까?

How to Make a Flexbox Row Fill Remaining Vertical Space?

Flexbox 레이아웃에서 세로 공간 활용률 100% 달성

Flexbox는 개발자가 반응성이 뛰어나고 동적인 레이아웃을 만들 수 있는 강력한 레이아웃 시스템입니다. 일반적인 시나리오 중 하나는 브라우저 창 내의 나머지 수직 공간을 자동으로 사용하는 Flexbox 레이아웃 행을 갖는 것입니다. 이 기사에서는 Flexbox 속성을 사용하여 이를 달성하는 방법을 살펴봅니다.

과제:

처음 두 행의 높이가 고정된 3행 Flexbox 레이아웃을 고려해 보세요. 문제는 브라우저 창의 남은 공간을 채우기 위해 세 번째 행을 세로로 늘려 콘텐츠를 그에 맞게 확장하는 것입니다.

해결책:

핵심 이 동작을 달성하려면 세 번째 행의 "flex" 속성을 1보다 큰 값으로 설정해야 합니다. 이는 flexbox가 고유 크기 이상으로 행을 늘리고 나머지 공간을 하위 항목에 분배하도록 지시합니다. 그러나 높이 속성을 100%로 설정하면 행 내의 콘텐츠가 브라우저 창을 자연스럽게 채우지 않기 때문에 작동하지 않습니다.

솔루션 구현:

이 레이아웃을 올바르게 구현하려면 다음 원칙이 적용되는지 확인하세요.

  • html, 본문 및 상위 div(래퍼)를 100%로 설정합니다. 이 상속을 통해 세 번째 행이 브라우저 창의 전체 높이를 상속할 수 있습니다.
  • 세 번째 행의 flex 속성을 1보다 큰 값으로 설정합니다(예: flex: 2). 이렇게 하면 행이 수직으로 늘어나 나머지 공간을 활용하게 됩니다.
  • 세 번째 행 내의 열에 최소 높이 100%를 추가하는 것을 고려해 보세요. 대부분의 최신 브라우저에서는 필요하지 않지만 브라우저 간 호환성을 제공할 수 있습니다.

예제 코드:

.wrapper, html, body {
    height: 100%;
    margin: 0;
}

.wrapper {
    display: flex;
    flex-direction: column;
}

#row1 {
    background-color: red;
}

#row2 {
    background-color: blue;
}

#row3 {
    background-color: green;
    flex: 2;
    display: flex;
}

#col1 {
    background-color: yellow;
    flex: 0 0 240px;
    min-height: 100%;
}

#col2 {
    background-color: orange;
    flex: 1 1;
    min-height: 100%;
}

#col3 {
    background-color: purple;
    flex: 0 0 240px;
    min-height: 100%;
}

결론:

이러한 지침을 따르면 자동으로 소비되는 Flexbox 레이아웃을 쉽게 만들 수 있습니다. 브라우저 창의 나머지 수직 공간. 이 기술은 콘텐츠 높이가 크게 달라질 수 있는 반응형 디자인에 특히 유용합니다.

위 내용은 Flexbox 행이 남은 수직 공간을 채우는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
CSS 카운터 : 자동 번호 매기기에 대한 포괄적 인 안내서CSS 카운터 : 자동 번호 매기기에 대한 포괄적 인 안내서May 07, 2025 pm 03:45 PM

csScounterSearedTomanageAutomaticNumberingInberingInwebDesigns.1) 1) theCanbeusedfortablestoffContents, ListItems 및 CustomNumbering.2) AdvancedUsesInSinestedNumberingsystems.3) CreativeUseNvolvecust를 CreativeSinvolecust.4) CreativeSinvolvecust

스크롤 구동 애니메이션을 사용한 현대 스크롤 그림자스크롤 구동 애니메이션을 사용한 현대 스크롤 그림자May 07, 2025 am 10:34 AM

특히 모바일 장치에 스크롤 그림자를 사용하는 것은 Chris가 이전에 다룬 미묘한 UX입니다. Geoff는 애니메이션 타임 라인 속성을 사용하는 새로운 접근 방식을 다루었습니다. 또 다른 방법이 있습니다.

이미지 맵 재 방문이미지 맵 재 방문May 07, 2025 am 09:40 AM

빠른 새로 고침을 통해 실행합시다. 이미지 맵은 html 3.2로 돌아가는데, 먼저 서버 측 맵과 클라이언트 측지 맵은 맵 및 영역 요소를 사용하여 이미지를 통해 클릭 가능한 영역을 정의했습니다.

DEVS 상태 : 모든 개발자를위한 설문 조사DEVS 상태 : 모든 개발자를위한 설문 조사May 07, 2025 am 09:30 AM

Devs State Survey는 이제 참여에 개방되어 있으며, 이전 설문 조사와 달리 코드, 직장, 건강, 취미 등을 제외한 모든 것을 포함합니다. 

CSS 그리드는 무엇입니까?CSS 그리드는 무엇입니까?Apr 30, 2025 pm 03:21 PM

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

CSS Flexbox 란 무엇입니까?CSS Flexbox 란 무엇입니까?Apr 30, 2025 pm 03:20 PM

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?Apr 30, 2025 pm 03:19 PM

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

CSS 박스 크기 부동산은 무엇을합니까?CSS 박스 크기 부동산은 무엇을합니까?Apr 30, 2025 pm 03:18 PM

이 기사는 요소 치수 계산 방법을 제어하는 ​​CSS 박스 크기 속성에 대해 설명합니다. Content-Box, Border-Box 및 Padding-Box와 같은 값과 레이아웃 설계 및 형태 정렬에 미치는 영향을 설명합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구