미디어 쿼리 없이 유동적인 3열~1열 레이아웃을 만드는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-11-15 07:17:02
원래의
593명이 탐색했습니다.

How to Create a Fluid 3-Column to 1-Column Layout Without Media Queries?

미디어 쿼리 없이: 유동적인 3열 데스크톱에서 1열 모바일 레이아웃 구현

전통적인 미디어 쿼리는 적응하는 데 중요한 역할을 합니다. 다양한 화면 크기에 따른 웹사이트 레이아웃. 그러나 진정으로 유연하고 반응이 빠른 디자인을 만들기 위해 미디어 쿼리가 필요 없는 대체 솔루션을 모색하려는 욕구가 있습니다.

데스크톱에서 3열 레이아웃을 사용하는 웹사이트를 생각해 보세요.

   |  |  |
---| ---| ---|
| 1 | 2 | 3 |
로그인 후 복사

그러나 모바일에서는 레이아웃이 단일 열로 변환되어야 합니다.

|
---|
| 1 |
| 2 |
| 3 |
로그인 후 복사

이를 동적으로 달성하려면, CSS의 강력한 기능이 도움이 됩니다.

그리드 및 클램프

.grid-wrapper {
   display: grid;
   gap: 15px;
   grid-template-columns: repeat(clamp(1, calc(100% - 500px), 3), 33%);
}
로그인 후 복사

repeat() 함수는 지정된 수의 열을 생성하고, 클램프()는 뷰포트가 500px 미만으로 줄어들면 최소 1개의 열.

Flexbox 및 Negative 여백

.flex-container {
   display: flex;
   flex-direction: row;
}

.flex-item {
   width: 33%; /* initial width */
   margin-right: -15px; /* negative margin to facilitate overlapping */
   background-color: red;
}

/* Breakpoint rule for smaller screens */
@media screen and (max-width: 500px) {
   .flex-item {
      margin-right: 0; /* remove negative margin on mobile */
   }
}
로그인 후 복사

이 접근 방식을 사용하면 큰 화면에서는 항목이 나란히 정렬되지만 좁은 화면에서는 수직으로 쌓이게 됩니다. 음수 여백은 처음에 겹침을 생성하며, 이는 작은 화면에서 이를 제거하여 수정됩니다.

결론

그리드, 클램프, Flexbox 및 음수 여백을 활용하면 가능합니다. 여러 열과 단일 열 사이에 원활하게 적용되는 유동적인 레이아웃을 생성하여 기본 레이아웃 변경을 위한 미디어 쿼리가 필요하지 않습니다.

위 내용은 미디어 쿼리 없이 유동적인 3열~1열 레이아웃을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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