문제 이해
설명된 시나리오에는 두 개의 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!