그리고 오스카상은…연대기 구성요소 코딩하기
올해 초 제 친구가 덴마크 코펜하겐에서 열린 코펜헬 페스티벌을 위해 작업하던 대형 포스터를 공유했습니다. 인상적인 2 x 12m 포스터는 헤비메탈 록에 특히 초점을 맞춰 지난 50년간의 중요한 문화 행사의 상세한 연대기를 선보였습니다. 그 장르를 위한 페스티벌!
독특한 "뱀 타임라인" 레이아웃이 특징인 디자인이
마음에 들었습니다. 이에 영감을 받아 HTML과 CSS를 사용하여 나만의 버전을 만들기로 결정했습니다. 하지만 약간 변형하여 1972년 이후의 "Best Picture" 오스카상 수상작에 초점을 맞췄습니다. 그렇습니다. 모두 보았습니다!
의미론적 마크업을 만드는 것부터 시작해 보겠습니다. 이 HTML은 타임라인의 구조를 제공하며 CSS 스타일을 적용하지 않아도 보기 좋게 보입니다.
<ol> <li value="1972"> <article> <img src="1972.jpg" alt="The Godfather"> <h4>The Godfather</h4> <small>A powerful crime saga following the Corleone family's rise and near fall within organized crime</small> </article> </li> </ol>
보시다시피 기본 브라우저 스타일만 사용해도 타임라인이 꽤 보기 좋게 보입니다!
참고:값 속성은 상위 항목이 순서가 지정된 목록,
인 경우
- 태그에만 유효합니다.
타임라인의 각 "열"에 대해 순서가 지정된 목록을 사용하고 이를 다음으로 래핑합니다.
<div class="ui-chronology"> <ol>...</ol> </div>목록 항목 스타일 지정
각 목록 항목은 두 개의 열로 구성된 그리드입니다. 검은 선과 연도는 각각 ::before 및 ::after 의사 요소로 표시됩니다. 두 의사 요소 모두 '그리드 스택' 기술(그리드 영역: 1/1)을 사용하여 동일한 그리드 셀(첫 번째 열)에 배치됩니다. 이를 통해 동일한 그리드 영역 내에서 여러 요소가 겹칠 수 있습니다.
li { display: grid; grid-template-columns: max-content 1fr; &::before { /* Vertical line */ content: ""; background: #000; grid-area: 1 / 1; margin-inline: auto; width: var(--bdw); } &::after { /* Year */ align-self: start; background-color: #000; border-radius: .175em; color: #FFF; content: attr(value); font-size: clamp(1rem, 0.2857rem + 2.2857vw, 2rem); font-weight: 900; grid-area: 1 / 1; padding-inline: .5ch; width: 5ch; } }
우리가 놓친 것은 "물결 모양의 커넥터"입니다. 타임라인 항목 사이에 '물결 모양의 커넥터'를 만들기 위해 '더미'
- 의 최상단과 하단에 배치할 예정이며, 장식용이므로 aria-hidden="true"를 추가했습니다.
<li value="0" aria-hidden="true"><i></i></li>
이제 커넥터의 CSS는 매우 복잡하므로 아래에 몇 가지 인라인 주석을 사용하여 구조를 보여드리겠습니다. 마지막에 있는 최종 CodePen 데모를 보고 코드를 자세히 살펴보세요.
ol { &:nth-of-type(odd) { li[value="0"] { &:last-of-type { /* Bottom Left Corner */ &::before { } } } /* FIRST COLUMN ONLY */ &:first-of-type { li[value="0"]:first-of-type { /* Hide Top Left Corner */ &::before { display: none; } } } &:not(:first-of-type) { li[value="0"] { &:first-of-type { /* Top Left Corner: Reverse */ &::before { } } } } &:last-of-type li[value="0"]:last-of-type i { ... } /* Round dot at the end of the last list */ &:last-of-type li[value="0"]:last-of-type i::after { ... } } /* EVEN COLUMNS */ &:nth-of-type(even) { li[value="0"] { &:first-of-type { /* Top Left Corner */ &::before { ... } } &:last-of-type { /* Bottom Left Corner: Reverse */ &::before { ... } } } } }
또한 모든 CSS는 다음과 같은
논리적 속성을 사용합니다.
border-block-width: 0 var(--bdw); border-inline-width: var(--bdw) 0; border-end-start-radius: var(--bdrs);왜 그럴까요?
오른쪽에서 왼쪽 텍스트 방향(dir="rtl")이 있는 사이트에서 작업하는 경우 모든 것이 이상하게 보일 것입니다. 이름에 left 또는 right가 포함된 속성을 사용하는 경우(예: padding-left). 논리적 속성을 사용하면 텍스트 방향을 전환하면 모든 것이 잘 보입니다.
정말 멋지네요! 이제 열을 더 추가해 보겠습니다.
"최종 둥근 점"이 어떻게 자동으로 마지막 열로 이동하는지 확인하세요!
이 튜토리얼을 마치겠습니다.
데모
새 창에서 데모를 열고 크기를 조정하여 열이 다시 흐르는지 확인하세요.
위 내용은 그리고 오스카상은…연대기 구성요소 코딩하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

다른 브라우저는 CSS 구문 분석에 차이가있어 주로 기본 스타일 차이, 박스 모델 계산 방법, Flexbox 및 그리드 레이아웃 지원 수준 및 특정 CSS 속성의 일관성없는 동작을 포함하여 일관되지 않은 디스플레이 효과가 발생합니다. 1. 기본 스타일 처리는 일치하지 않습니다. 해결책은 CSSRESET 또는 NALLER.CSS를 사용하여 초기 스타일을 통합하는 것입니다. 2. IE의 이전 버전의 박스 모델 계산 방법은 다릅니다. 상자 크기 : 통일 된 방식으로 테두리 박스를 사용하는 것이 좋습니다. 3. Flexbox 및 Grid는 Edge Case 또는 Old 버전에서 다르게 수행합니다. 더 많은 테스트 및 AutopRefixer 사용; 4. 일부 CSS 속성 동작은 일관성이 없습니다. Caniuse는 상담하고 다운 그레이드해야합니다.

Accent-Color는 CSS에서 확인란, 라디오 버튼 및 슬라이더와 같은 양식 요소의 하이라이트 색상을 사용자 정의하는 데 사용되는 속성입니다. 1. 확인란의 파란색 확인 표시를 빨간색으로 변경하는 것과 같이 양식 컨트롤의 선택한 상태의 기본 색상을 직접 변경합니다. 2. 지원되는 요소는 type = "checkbox", type = "radio"및 type = "range"의 입력 상자를 포함합니다. 3. Accent-Color를 사용하면 복잡한 맞춤형 스타일과 추가 DOM 구조를 피하고 기본 접근성을 유지할 수 있습니다. 4. 일반적으로 현대식 브라우저에서 지원되며 오래된 브라우저는 다운 그레이드해야합니다. 5. Accent-col을 설정하십시오

Thevertical-alignpropertyincssalignsinlinlineortable-cellelementsically

USEAUTOMATEDTOOLSPURGECSSORUCNSSCANANDREMOVEUNUSEDCSS; 2. INTEGRATEPURGINGINTOYOURBUILDPROCESSVIAWEBPACK, vite, ortailwind'ScontentConfiguration; 3.auditcsSusagewithchromedevToolsCovereAvoidtoidrestyledingneatiledneatiled의 3.auditcsSusage

CSS의 텍스트 색상을 변경하려면 색상 속성을 사용해야합니다. 1. 색상 속성을 사용하여 텍스트 전경을 사용하여 색상 이름 (예 : 빨간색), 16 진 코드 (예 : #FF0000), RGB 값 (예 : RGB (255,0,0)), HSL 값 (예 : HSL (0,100%, 50%) 및 RGBA 또는 HSLA (RGBA) (255,0.0); 2. H1 ~ H6 제목, 단락 P, 링크 A와 같은 텍스트가 포함 된 모든 요소에 색상을 적용 할 수 있습니다 (A : A : 방문, A : 호버, A : Active, Div, Span 등; 3. 대부분

배경 필터는 요소 뒤의 내용에 시각적 효과를 적용하는 데 사용됩니다. 1. 배경 필터 : Blur (10px) 및 기타 구문을 사용하여 프로스트 유리 효과를 달성합니다. 2. 흐림, 밝기, 대비 등과 같은 여러 필터 기능을 지원하며 중첩 될 수 있습니다. 3. 유리 카드 디자인에 종종 사용되며 요소가 배경과 겹치도록해야합니다. 4. 현대식 브라우저는 지원이 좋으며 @Supports는 다운 그레이드 솔루션을 제공하는 데 사용될 수 있습니다. 5. 성능을 최적화하기 위해 과도한 흐림 값과 빈번한 다시 그리기를 피하십시오. 이 속성은 요소 뒤에 내용이있는 경우에만 적용됩니다.

먼저 JavaScript를 사용하여 사용자 시스템 환경 설정과 로컬로 저장된 테마 설정을 얻고 페이지 테마를 초기화하십시오. 1. HTML 구조에는 주제 스위칭을 트리거하는 버튼이 포함되어 있습니다. 2. CSS 사용 : 루트는 밝은 테마 변수를 정의하기 위해 루트, .dark-mode 클래스는 어두운 테마 변수를 정의하고 var ()를 통해 이러한 변수를 적용합니다. 3. JavaScript는 색채를 선호하는 것을 감지하고 초기 테마를 결정하기 위해 LocalStorage를 읽습니다. 4. 버튼을 클릭 할 때 HTML 요소에서 Dark-Mode 클래스를 전환하고 현재 상태를 LocalStorage에 저장합니다. 5. 모든 색상 변경 사항은 0.3 초 전환 애니메이션을 동반하여 사용자를 향상시킵니다.

theaspect-ratiocsspropertydefinesthewidth-heightratioofanlement
