이 글의 내용은 순수 CSS를 사용하여 항공기 현창 스타일 토글 컨트롤을 구현하는 방법에 대한 내용이며, 필요한 친구들이 참고할 수 있기를 바랍니다. 당신.
효과 미리보기
소스코드 다운로드
https ://github.com/comehope/front-end-daily-challenges
코드 해석
Define dom, .windows
컨테이너는 현창을 나타냅니다. , 하위 요소인 .curtain
은 커튼을 나타냅니다. .windows
容器表示舷窗,它的子元素 .curtain
表示窗帘:
<figure> <div></div> </figure>
居中显示:
body { margin: 0; height: 100vh; display: flex; align-items: center; justify-content: center; background-color: skyblue; }
设置舷窗的尺寸,因为后面还会用到字号,所以字号用变量定义:
:root { --font-size: 10px; } .window { position: relative; box-sizing: border-box; width: 25em; height: 35em; font-size: var(--font-size); background-color: #d9d9d9; }
用阴影画出厚窗框:
.window { border-radius: 5em; box-shadow: inset 0 0 8em rgba(0, 0, 0, 0.2), 0 0 0 0.4em #808080, 0 0 0 4em whitesmoke, 0 0 0 4.4em #808080, 0 2em 4em 4em rgba(0, 0, 0, 0.1); }
设置窗帘样式,和窗口尺寸一样,但不拉到底:
.window .curtain { position: absolute; width: inherit; height: inherit; border-radius: 5em; box-shadow: 0 0 0 0.5em #808080, 0 0 3em rgba(0, 0, 0, 0.4); background-color: whitesmoke; left: 0; top: -5%; }
用伪元素在窗帘上画出指示灯,当窗帘关闭时亮红色光:
.window .curtain::before { content: ''; position: absolute; width: 40%; height: 0.8em; background-color: #808080; left: 30%; bottom: 1.6em; border-radius: 0.4em; } .window .curtain::after { content: ''; position: absolute; width: 1.6em; height: 0.8em; background-image: radial-gradient(orange, orangered); bottom: 1.6em; border-radius: 0.4em; left: calc((100% - 1.6em) / 2); }
以上是舷窗关闭时的样子,接下来绘制舷窗打开时的效果。
先在 dom 中添加一个 checkbox
,当它被 checked
时即表示舷窗被打开:
<figure> <div></div> </figure>
隐藏 checkbox
,用 opacity(0)
可以使元素在不可见的状态下仍可交互,把它的尺寸设置得到舷窗一样大,并且图层在舷窗之上,得到的效果就是点击舷窗时实际是点击了 checkbox
:
.toggle { position: absolute; filter: opacity(0); width: 25em; height: 35em; font-size: var(--font-size); cursor: pointer; z-index: 2; }
当舷窗打开时,.curtain
要向上移动,并且指示灯亮绿色光:
.window .curtain { transition: 0.5s ease-in-out; } .toggle:checked ~ .window .curtain { top: -90%; } .toggle:checked ~ .window .curtain::after { background-image: radial-gradient(lightgreen, limegreen); }
隐藏超出窗户的部分:
.window { overflow: hidden; }
接下来绘制舷窗外的风景。
在 dom 中增加表示云朵的 .clouds
元素,其中的 5 个 <span></span>
<input> <figure> <div></div> <div> <span></span> <span></span> <span></span> <span></span> <span></span> </div> </figure>가운데 표시:
.window .clouds { position: relative; width: 20em; height: 30em; background-color: deepskyblue; box-shadow: 0 0 0 0.4em #808080; left: calc((100% - 20em) / 2); top: calc((100% - 30em) / 2); border-radius: 7em; }글꼴 크기에 따라 현창의 크기를 설정합니다. 나중에 사용할 수 있으므로 글꼴 크기는 변수로 정의됩니다:
.clouds span { position: absolute; width: 10em; height: 4em; background-color: white; top: 20%; border-radius: 4em; }그림자를 사용하여 두꺼운 창틀 그리기:
.clouds span::before, .clouds span::after { content: ''; position: absolute; width: 4em; height: 4em; background-color: white; border-radius: 50%; } .clouds span::before { top: -2em; left: 2em; } .clouds span::after { top: -1em; right: 1em; }커튼 스타일을 다음과 같은 크기로 설정 창문은 있지만 바닥은 아님:
.clouds span { animation: move 4s linear infinite; } @keyframes move { from { left: -150%; } to { left: 150%; } }의사 요소를 사용하여 커튼에 표시등을 그립니다. 커튼이 닫히면 빨간색으로 켜집니다.
.clouds span:nth-child(2) { top: 40%; animation-delay: -1s; } .clouds span:nth-child(3) { top: 60%; animation-delay: -0.5s; } .clouds span:nth-child(4) { top: 20%; transform: scale(2); animation-delay: -1.5s; } .clouds span:nth-child(5) { top: 70%; transform: scale(1.5); animation-delay: -3s; }위 현창이 닫혀 있을 때의 모습입니다. 다음으로 현창이 열렸을 때의 효과를 그립니다.
먼저 DOM에 체크박스
를 추가하세요. 체크
되면 포트홀이 열린다는 뜻입니다:
.window .clouds { overflow: hidden; }
Hide 확인란, opacity(0)
를 사용하여 요소가 보이지 않을 때에도 상호 작용하도록 만들고 크기를 현창만큼 크게 설정하고 레이어가 현창 위에 있습니다. 효과는 현창을 클릭할 때 실제로 체크박스
를 클릭하는 것입니다:
When the porthole is open, .curtain
위로 움직이고 표시등이 녹색으로 변합니다. 표시등:
rrreee
.clouds
요소를 추가하고 5개의 <span></span>
하위 요소는 각각 1개의 흰 구름을 나타냅니다. #🎜🎜#rrreee #🎜🎜#구름 컨테이너를 사용하여 창 밖의 푸른 하늘 그리기: #🎜🎜#rrreee#🎜🎜#각 구름은 3개의 부분으로 구성됩니다. 먼저 가장 큰 부분을 그립니다. #🎜🎜#rrreee#🎜🎜# 그런 다음. 의사 요소 사용 2개의 돌출된 호 그리기: #🎜🎜#rrreee#🎜🎜# 떠 있는 구름의 애니메이션 효과 높이기: #🎜🎜#rrreee#🎜🎜# 각 구름의 크기와 위치를 약간 변경: #🎜🎜# rrreee #🎜🎜#마지막으로 컨테이너 외부의 콘텐츠를 숨깁니다. #🎜🎜#rrreee#🎜🎜#완료되었습니다! #🎜🎜##🎜🎜##🎜🎜##🎜🎜#위 내용은 순수 CSS를 사용하여 항공기 현창 스타일 토글 컨트롤을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Flexbox 또는 그리드 선택은 레이아웃 요구 사항에 따라 다릅니다. 1) Flexbox는 탐색 표시 줄과 같은 1 차원 레이아웃에 적합합니다. 2) 그리드는 매거진 레이아웃과 같은 2 차원 레이아웃에 적합합니다. 두 사람은 프로젝트에 사용하여 레이아웃 효과를 향상시킬 수 있습니다.

CSS 파일을 포함시키는 가장 좋은 방법은 태그를 사용하여 HTML 부분에 외부 CSS 파일을 소개하는 것입니다. 1. 태그를 사용하여 외부 CSS 파일을 소개합니다. 2. 작은 조정의 경우 인라인 CSS를 사용할 수 있지만주의해서 사용해야합니다. 3. 대규모 프로젝트는 SASS와 같은 CSS 전 처리기를 사용하여 @Import를 통해 다른 CSS 파일을 가져올 수 있습니다. 4. 성능의 경우 CSS 파일을 병합하고 CDN을 사용해야하고 CSSNANO와 같은 도구를 사용하여 압축해야합니다.

예, YoushouldLearnbothflexBoxAndgrid.1) FlexBoxisIdealforone-Dimensional, FlexiblelayoutSlikenavigationMenus.2) GridexCelsIntwo-Dimensional, ComplexDesignsSuchasmagazinElayouts.3) 결합 된 BothenSlayoutFlexibility 및 HeartingFortructur

자신의 코드를 리팩터링하는 것은 어떤 모습입니까? John Rhea는 자신이 쓴 오래된 CSS 애니메이션을 선택하고 최적화하는 사고 과정을 살펴 봅니다.

cssanimationsarenherinly에 hardbutreepracticenderstandingofcsspropertiesandtimingflestions.1) startsimpleants withsimpleatslikeScalingabuttononHoverusingKeyframes.2) useAsingfuctionslikecubic-bezierfornateffects, 그러한 분위기, 3)

@keyframesispopularduetoitstativerstatility 및 powerincreatingsmoothcssanimations.keytricksinclude : 1) states 사이에 moothtransitionsbettites, 2) 애니메이션 multiplepropertiessimultory, 3) vendorPixesforBrowsercompatibility, 4) 빗질을 사용하여

csScounterSearedTomanageAutomaticNumberingInberingInwebDesigns.1) 1) theCanbeusedfortablestoffContents, ListItems 및 CustomNumbering.2) AdvancedUsesInSinestedNumberingsystems.3) CreativeUseNvolvecust를 CreativeSinvolecust.4) CreativeSinvolvecust

특히 모바일 장치에 스크롤 그림자를 사용하는 것은 Chris가 이전에 다룬 미묘한 UX입니다. Geoff는 애니메이션 타임 라인 속성을 사용하는 새로운 접근 방식을 다루었습니다. 또 다른 방법이 있습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

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

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

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.