찾다
웹 프론트엔드CSS 튜토리얼CSS 그리드 및 SVG 필터를 사용한 아트

그리드 자동 흐름의 강력한 기능인 밀도를 탐색해 본 적이 있습니까? 무작위로 생성된 값(설정된 범위 내로 제한됨)과 결합하면 그리드-열 및 그리드-행 속성을 사용하여 멋진 그리드 기반 아트를 만들 수 있습니다. 뛰어들어 보세요!

먼저 기본 그리드 구조를 만들어 보겠습니다.

main {
  display: grid;
  grid-auto-flow: dense;
  grid-template-columns: repeat(auto-fill,
 minmax(var(--w, 4cqi), 1fr));
}
  • 디스플레이: 그리드: CSS 그리드 레이아웃을 설정합니다.
  • grid-auto-flow:density: 빈 공간을 최소화하기 위해 항목 위치를 변경하여 그리드의 공백을 자동으로 채웁니다.
  • Grid-template-columns: 반응형 열 레이아웃을 정의합니다. 여기서는 사용 가능한 공간을 채우기 위해(자동 채우기) 열이 자동으로 생성되며, 각 열의 최소 너비는 --w(기본값은 4cqi)이고 최대 너비는 1fr입니다.

이때 --w는 정의되지 않았으므로 기본값(4cqi)을 사용합니다. 초기 그리드의 모습은 다음과 같습니다.

Art with CSS Grid and SVG filters

다음으로 그리드를 여러 개의 노드로 채울 것입니다. JavaScript로 렌더링할 때 노드당 2개의 변수를 추가합니다.

  • --gc: 확장할 열 수.
  • --gr: 확장할 행 수.

JavaScript에서 임의의 값을 생성하는 방법은 다음과 같습니다.

const random = (min, max) => 
  Math.random() * (max - min) + min

const column = () => 
`--gc:${Math.floor(random(0, 4))};`

const row = () => 
`--gr:${Math.floor(random(0, 3))};`

CSS에서는 다음과 같은 사용자 정의 속성을 적용합니다.

b {
  background: oklch(var(--l) var(--c) var(--h) / var(--a));
  grid-column: span var(--gc);
  grid-row: span var(--gr, 1);
}

작은 도우미 메소드를 사용하여 oklch에 임의의 색상을 추가해 보겠습니다.

const color = () => `--l:${
  random(0, 100)}%;--c:${
  random(0, 0.5)};--h:${
  random(0, 60)};--a:${
  random(0.2, 1)};`

이제 다음 내용을 얻을 수 있습니다.

Art with CSS Grid and SVG filters

grid-auto-flow: 촘촘합니다!

감사합니다.

더 동적으로 만들기 위해 회전 및 크기 조정과 같은 변환을 추가해 보겠습니다.

b {
  rotate: var(--r);
  scale: var(--s);
}

JavaScript에서는 무작위 변환 값을 생성합니다.

const transform = () => 
`--r:${random(-2, 3)}deg;
--s:${random(0.8, 1.2)};`

확인해 보세요:

Art with CSS Grid and SVG filters

멋지네요! 이제 한 단계 더 발전시키기 위해 멋진 SVG 필터를 추가해 보겠습니다.

JavaScript에서는 노드별로 무작위 필터를 선택하는 또 다른 작은 도우미 메서드를 추가합니다.

const filter = () =>
  `--url:url(#${
    [
      "pencilTexture",
      "pencilTexture2",
      "pencilTexture3",
      "pencilTexture4",
    ][Math.floor(random(0, 4))]
  });`

이는 다음을 제공합니다.

Art with CSS Grid and SVG filters

이제 --w 속성과 요소 수만 조정하면 매우 다양한 예술 작품을 생성할 수 있습니다.

Art with CSS Grid and SVG filters

또는:

Art with CSS Grid and SVG filters

색상 방법으로 시작 및 중지 값을 조정할 수도 있습니다.

Art with CSS Grid and SVG filters


데모

여기 Codepen 데모가 있습니다. 아트워크 아래에 컨트롤을 추가했으므로 속성을 쉽게 조정할 수 있습니다.

위 내용은 CSS 그리드 및 SVG 필터를 사용한 아트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
스크린 독자를 탈취시킵니다. 액세스 가능한 양식 및 모범 사례스크린 독자를 탈취시킵니다. 액세스 가능한 양식 및 모범 사례Mar 08, 2025 am 09:45 AM

이것은 우리가 양식 접근성에 대해 한 작은 시리즈의 세 번째 게시물입니다. 두 번째 게시물을 놓친 경우 "사용자 초점 관리 : Focus-Visible"을 확인하십시오. ~ 안에

Smart Forms 프레임 워크로 JavaScript 연락처 양식 작성Smart Forms 프레임 워크로 JavaScript 연락처 양식 작성Mar 07, 2025 am 11:33 AM

이 튜토리얼은 Smart Forms 프레임 워크를 사용하여 전문적인 JavaScript 양식을 작성하는 것을 보여줍니다 (참고 : 더 이상 사용할 수 없음). 프레임 워크 자체를 사용할 수 없지만 원칙과 기술은 다른 형태의 건축업자와 관련이 있습니다.

WordPress 블록 및 요소에 상자 그림자를 추가합니다WordPress 블록 및 요소에 상자 그림자를 추가합니다Mar 09, 2025 pm 12:53 PM

CSS Box-Shadow 및 개요 속성은 주제를 얻었습니다. 실제 테마에서 어떻게 작동하는지에 대한 몇 가지 예와 이러한 스타일을 WordPress 블록 및 요소에 적용 해야하는 옵션을 보자.

GraphQL 캐싱 작업GraphQL 캐싱 작업Mar 19, 2025 am 09:36 AM

최근에 GraphQL 작업을 시작했거나 장단점을 검토 한 경우 "GraphQL이 캐싱을 지원하지 않음"또는

첫 번째 맞춤형 전환을 만듭니다첫 번째 맞춤형 전환을 만듭니다Mar 15, 2025 am 11:08 AM

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스Mar 10, 2025 am 11:37 AM

이 기사에서 우리는 스크롤 바의 세계로 뛰어들 것입니다. 너무 화려하게 들리지는 않지만 잘 설계된 페이지가 손을 잡고 있습니다.

쇼, 말하지 마십시오쇼, 말하지 마십시오Mar 16, 2025 am 11:49 AM

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

NPM 명령은 무엇입니까?NPM 명령은 무엇입니까?Mar 15, 2025 am 11:36 AM

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.

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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

맨티스BT

맨티스BT

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

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.