웹 프론트엔드 CSS 튜토리얼 CSS 그리드가 벽돌 레이아웃에 충분하지 않은 이유

CSS 그리드가 벽돌 레이아웃에 충분하지 않은 이유

Dec 27, 2024 am 07:30 AM

Why CSS Grid Isn’t Enough for Masonry Layouts

벽돌 레이아웃을 구현하기 위한 사용하기 쉬운 방법은 웹 개발자 커뮤니티에서 오랫동안 추구해 왔습니다. Pinterest 및 관련 디자인 덕분에 CSS만 사용하여 미학적으로 역동적인 그리드를 만드는 것은 어려웠습니다. Chrome 팀은 CSS 그리드 레이아웃 사양에 벽돌 기능을 추가해야 한다는 최근 권장 사항에도 불구하고 이 전략이 최선이 아닐 수 있다고 주장합니다. 다음은 벽돌이 고유한 레이아웃 기술을 가져야 한다고 생각하는 몇 가지 이유와 개발자에게 잠재적인 이점을 제공합니다.

CSS 그리드에 벽돌을 추가하는 것에 반대하는 사례

1. 성능 문제

CSS 그리드 및 벽돌 레이아웃은 근본적으로 다른 방식으로 항목 배치를 처리합니다.

  • CSS 그리드: 모든 항목은 레이아웃 전에 배치되므로 브라우저가 정확한 트랙 크기와 배치를 계산할 수 있습니다.
  • Masonry: 항목은 배치된 대로 배치되므로 고정 트랙 크기와 고유 트랙 크기를 혼합할 때 심각한 성능 문제가 발생할 수 있는 동적 계산이 필요합니다.

grid-template-columns: 200px auto 200px와 같은 혼합 트랙 정의가 있는 그리드를 고려해 보세요. 벽돌을 사용하면 브라우저는 가능한 모든 구성의 모든 항목을 미리 레이아웃해야 하므로 대규모 그리드에서는 기하급수적인 복잡성이 발생합니다. 이는 서브그리드와 같은 고급 기능을 사용할 때 특히 문제가 됩니다.

이러한 본질적인 제한이 있는 레이아웃 방법을 제공하지 않기 위해 우리는 CSS 그리드와 석조 구조를 분리하는 솔루션을 제안합니다.

2. 사양 복잡성

석조를 그리드 사양에 병합하면 서식 지정 컨텍스트의 핵심 원칙과 충돌하는 불일치가 발생합니다.

  • 정렬 속성: 그리드는 6개의 정렬 속성을 지원하지만 벽돌은 Flexbox와 같은 하위 집합만 사용합니다.
  • 배치 속성: 그리드에는 4개의 배치 속성(예: 그리드-기둥-시작)이 있지만 벽돌에는 2개만 필요합니다.
  • 트랙 크기 조정: 그리드 템플릿 열: 반복(자동 채우기, 최대 콘텐츠)과 같은 특정 패턴은 벽돌에서는 의미가 있지만 그리드에서는 유효하지 않아야 합니다.

이러한 불일치를 도입하면 어떤 기능이 어떤 상황에서 작동하는지 기억해야 하므로 개발자의 인지 부하가 ​​증가합니다. 이러한 단편화는 혼란과 오류를 초래할 수 있습니다.

제안: 별도의 레이아웃 방법으로서의 석조 공사

석조를 CSS 그리드와 묶는 대신 디스플레이: 석조를 사용하여 독립형 레이아웃 방법으로 정의하는 것이 좋습니다. 이 접근 방식은 위에서 설명한 함정을 피하면서 개발자가 그리드에 대해 선호하는 모든 유연성을 유지합니다.

고전적인 석조 레이아웃

다음을 사용하여 동일한 크기의 기둥을 사용한 간단한 석조 레이아웃을 얻을 수 있습니다.

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}
로그인 후 복사
로그인 후 복사

혼합 트랙 크기

좁은 열과 넓은 열이 교대로 있는 레이아웃의 경우:

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 1rem;
}
로그인 후 복사
로그인 후 복사

트랙 자동 크기 조절

콘텐츠에 따라 트랙 크기가 자동으로 조정되도록 허용:

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, minmax(8rem, 1fr) minmax(16rem, 2fr)) minmax(8rem, 1fr);
  gap: 1rem;
}
로그인 후 복사

스패닝 및 배치

여러 트랙에 걸쳐 항목을 활성화하려면:

.masonry {
  display: masonry;
  masonry-template-tracks: repeat(auto-fill, auto);
  gap: 1rem;
}
로그인 후 복사

별도의 조적 레이아웃의 장점

명확성: 개발자는 CSS Grid 호환성의 미묘한 차이에 대해 걱정하지 않고 벽돌을 사용할 수 있습니다.

유연성: 새로운 제약 조건을 도입하지 않고도 그리드와 유사한 모든 기능을 계속 사용할 수 있습니다.

미래 보장: 전용 벽돌 사양은 브라우저 전체에서 일관된 동작을 보장하고 불필요한 복잡성을 방지합니다.

위 내용은 CSS 그리드가 벽돌 레이아웃에 충분하지 않은 이유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Google 글꼴 변수 글꼴 Google 글꼴 변수 글꼴 Apr 09, 2025 am 10:42 AM

Google Fonts가 새로운 디자인 (트윗)을 출시 한 것을 볼 수 있습니다. 마지막 큰 재 설계와 비교할 때 이것은 훨씬 더 반복적 인 느낌이 듭니다. 차이를 간신히 말할 수 있습니다

HTML, CSS 및 JavaScript로 애니메이션 카운트 다운 타이머를 만드는 방법 HTML, CSS 및 JavaScript로 애니메이션 카운트 다운 타이머를 만드는 방법 Apr 11, 2025 am 11:29 AM

프로젝트에 카운트 다운 타이머가 필요한 적이 있습니까? 그런 것은 플러그인에 도달하는 것이 당연하지만 실제로는 훨씬 더 많습니다.

HTML 데이터 속성 안내서 HTML 데이터 속성 안내서 Apr 11, 2025 am 11:50 AM

HTML, CSS 및 JavaScript의 데이터 속성에 대해 알고 싶었던 모든 것.

Sass를 더 빨리 만들기위한 개념 증명 Sass를 더 빨리 만들기위한 개념 증명 Apr 16, 2025 am 10:38 AM

새로운 프로젝트가 시작될 때, Sass 컴파일은 눈을 깜박이게합니다. 특히 BrowserSync와 짝을 이루는 경우 기분이 좋습니다.

SVG에서 타탄 패턴을 생성하는 정적 사이트를 만드는 방법 SVG에서 타탄 패턴을 생성하는 정적 사이트를 만드는 방법 Apr 09, 2025 am 11:29 AM

타탄은 일반적으로 스코틀랜드, 특히 세련된 킬트와 관련된 패턴의 천입니다. tartanify.com에서 우리는 5,000 개가 넘는 타탄을 모았습니다

WordPress 테마에서 VUE 구성 요소를 빌드하는 방법 WordPress 테마에서 VUE 구성 요소를 빌드하는 방법 Apr 11, 2025 am 11:03 AM

Inline-Template 지시문을 사용하면 기존 WordPress 마크 업에 대한 진보적 인 향상으로 풍부한 VUE 구성 요소를 구축 할 수 있습니다.

PHP는 템플릿을위한 A-OK입니다 PHP는 템플릿을위한 A-OK입니다 Apr 11, 2025 am 11:04 AM

PHP 템플릿은 종종 서브 파 코드를 용이하게하는 데 나쁜 랩을 얻지 만, 그렇지 않아야합니다. PHP 프로젝트가 기본을 시행 할 수있는 방법을 살펴 보겠습니다.

접근 가능한 색상 조합을 생성하기 위해 SASS를 프로그래밍합니다 접근 가능한 색상 조합을 생성하기 위해 SASS를 프로그래밍합니다 Apr 09, 2025 am 11:30 AM

우리는 항상 웹에 더 액세스 할 수 있도록하고 있습니다. 색상 대비는 수학 일 뿐이므로 Sass는 디자이너가 놓친 에지 케이스를 다룰 수 있습니다.

See all articles