고정 위치 동작의 불일치 조사
MDN 문서에서는 고정 위치 지정을 요소를 상대 배치에서 고정 배치로 한 번 전환하는 속성으로 묘사합니다. 정의된 임계값을 초과했습니다. 그러나 실제로는 다르게 동작합니다. 이러한 불일치는 상태가 구현되는 순서에 대한 오해에서 비롯됩니다.
MDN에 따르면 고정 위치 요소는 처음에는 임계값을 초과할 때까지 상대 위치 요소처럼 동작합니다. 그러나 Bottom:0이 지정된 컨텍스트에서는 초기 상태에서 이미 임계값을 초과했습니다. 결과적으로 요소는 고정 배치에 직접 들어가고 요소 위치가 뷰포트 하단에서 0px를 초과할 때까지 그대로 유지됩니다.
고정 위치 상태 이해
위치:sticky에는
- 상대적이라는 두 가지 상태가 있습니다. 상태: 요소는 상대적으로 위치가 지정된 개체처럼 동작합니다.
- 고정 상태: 요소는 뷰포트에 대해 고정된 위치에 고정됩니다.
초기 상태는 요소의 배치와 정의된 임계값에 따라 결정됩니다. Bottom:0의 경우 임계값을 즉시 초과하여 초기 고정 상태로 전환됩니다. 뷰포트가 스크롤되면 아래쪽 가장자리로부터의 거리가 0px보다 커질 때까지 요소는 고정된 상태로 유지됩니다. 이 시점에서는 상대 상태로 되돌아갑니다.
동작 설명
다음 코드 조각을 고려하세요.
body { height:150vh; margin:0; display:flex; flex-direction:column; border:2px solid; margin:50px; } .b { margin-top:auto; position:sticky; bottom:0; } .a { position:sticky; top:0; }
<div class="a"> I will start relative then I will be fixed </div> <div class="b"> I will start fixed then I will be relative </div>
top:0인 요소 A는 처음에는 상대적으로 동작하고 맨 위에 도달하면 고정으로 전환됩니다. 뷰포트의 하단:0인 요소 B는 즉시 고정 위치에서 시작하고 뷰포트 하단으로부터의 거리가 0픽셀을 초과하면 상대 위치로 전환됩니다.
위 내용은 고정 위치 지정이 MDN 문서에 설명된 것과 다르게 동작하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

WebStorm Mac 버전
유용한 JavaScript 개발 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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