래핑할 때 행 전체에 걸쳐 일관된 Flex 항목 너비를 유지하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-24 19:46:12
원래의
521명이 탐색했습니다.

How to Maintain Consistent Flex Item Widths Across Rows When Wrapping?

래핑된 Flex 항목이 이전 행 너비를 유지하도록 보장

Flex 컨테이너에서 Flex 항목이 래핑될 때 허용되는 최대 공간을 차지하는 경향이 있어 너비가 일치하지 않게 됩니다. 서로 다른 행의 항목 사이. 이 문제를 해결하기 위해 다음 CSS 트릭을 사용할 수 있습니다.

솔루션 1: Flex 항목용 사용자 정의 Mixin

Mixin:

@mixin flex-wrap-fix($flex-basis, $max-viewport-width: 2000px) {
  flex-grow: 1;
  flex-basis: $flex-basis;
  max-width: 100%;

  $multiplier: 1;
  $current-width: 0px;

  @while $current-width < $max-viewport-width {
    $current-width: $current-width + $flex-basis;
    $multiplier: $multiplier + 1;

    @media(min-width: $flex-basis * $multiplier) {
      max-width: percentage(1/$multiplier);
    }
  }
}
로그인 후 복사

사용법:

플렉스에 믹스인 적용 item:

.flex-item {
  @include flex-wrap-fix(100px)
}
로그인 후 복사

솔루션 2: 요소 쿼리용 Flex 컨테이너 믹스인

Mixin:

@mixin flex-container-wrap-items($flex-basis, $max-expected-width: 2000px) {
  display: flex;
  flex-wrap: wrap;

  > * {
    max-width: 100%;
    flex-grow: 1;
    flex-basis: $flex-basis;
  }

  $multiplier: 1;
  $current-width: 0px;

  @while $current-width < $max-expected-width {
    $current-width: $current-width + $flex-basis;
    $multiplier: $multiplier + 1;

    &[min-width~="#{$flex-basis * $multiplier}"] > * {
      max-width: percentage(1/$multiplier);
    }
  }
}
로그인 후 복사

사용법:

믹스인을 플렉스 컨테이너:

.flex-container {
  @include flex-container-wrap-items(100px)
}
로그인 후 복사

위 내용은 래핑할 때 행 전체에 걸쳐 일관된 Flex 항목 너비를 유지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿