>웹 프론트엔드 >CSS 튜토리얼 >처음에 숨겨진 요소에서 CSS 전환이 작동하지 않는 이유는 무엇입니까?

처음에 숨겨진 요소에서 CSS 전환이 작동하지 않는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-15 15:11:02492검색

Why Don't CSS Transitions Work on Initially Hidden Elements?

초기 숨겨진 요소에서 CSS 전환이 작동하지 않음

문제 이해

설명된 시나리오에는 두 개의 div가 있습니다. , 그 중 하나는 처음에 display:none을 사용하여 숨겨졌습니다. show(),toggle() 등의 메소드를 사용하여 숨겨진 div를 표시하는 경우 해당 속성 전환이 원활하게 발생하지 않습니다. 대신 원하는 끝 위치에 div가 즉시 나타납니다.

동작의 원인

이 동작을 이해하려면 CSSOM( CSS 개체 모델) 및 DOM(문서 개체 모델).

CSS 전환은 전환의 시작점을 결정하기 위해 요소의 초기 계산 스타일 값을 아는 데 의존합니다. 그러나 display:none이 있는 요소는 CSSOM에서 표시되는 것으로 간주되지 않으므로 계산된 스타일 값이 없습니다.

리플로우의 영향

리플로우는 다시 계산하는 브라우저 작업입니다. DOM 또는 스타일 규칙의 변경 사항에 따른 문서 레이아웃. display:none이 제거되면 브라우저는 DOM 및 계산된 스타일 값을 업데이트하기 위해 리플로우를 시작합니다.

주어진 시나리오에서 리플로우가 발생하기 전에 전환이 시작되면 숨겨진 div에 대한 초기 계산된 스타일 값이 유효하지 않아 갑자기 나타납니다.

문제 해결

옵션 1: $.animate() 사용

$.animate()는 애니메이션을 실행하기 전에 리플로우를 트리거하여 계산된 스타일 값이 최신인지 확인합니다.

옵션 2: 수동으로 리플로우 강제 적용

requestAnimationFrame()을 사용하면 다음 페인트 작업 전에 코드 실행을 예약할 수 있습니다. 콜백 내에서 document.body.offsetHeight와 같은 메서드를 사용하여 리플로우를 강제한 다음 원하는 CSS 속성 값을 설정하여 즉시 전환을 트리거할 수 있습니다.

결론

CSS 전환 중에 처음에 숨겨진 요소가 갑자기 나타나는 이유는 유효한 계산 스타일 값이 부족하기 때문입니다. 리플로우 프로세스를 이해하고 리플로우를 강제하는 기술을 사용함으로써 처음에 숨겨진 요소의 원활한 전환을 보장할 수 있습니다.

위 내용은 처음에 숨겨진 요소에서 CSS 전환이 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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