> 웹 프론트엔드 > CSS 튜토리얼 > CSS3 호버 애니메이션이 완전히 완료되도록 하려면 어떻게 해야 합니까?

CSS3 호버 애니메이션이 완전히 완료되도록 하려면 어떻게 해야 합니까?

Patricia Arquette
풀어 주다: 2024-12-05 18:19:11
원래의
721명이 탐색했습니다.

How Can I Ensure CSS3 Hover Animations Complete Fully?

호버의 CSS3 애니메이션: 전체 완료 보장

CSS3에서 호버 애니메이션은 시각적으로 매력적인 방법을 제공하여 사용자 경험을 향상시킵니다. 그러나 요소에서 커서를 제거할 때 애니메이션이 갑자기 중지되는 경우 일반적인 문제가 발생합니다. 이 문제는 특히 애니메이션이 전체 과정을 실행하도록 하려는 경우 실망스러울 수 있습니다.

중단이 포함된 키프레임 애니메이션

제공된 코드 조각은 트리거된 간단한 바운스 애니메이션을 보여줍니다. :hover 상태를 사용합니다. 그러나 질문에서 언급했듯이 마우스 커서가 요소를 벗어나면 애니메이션이 조기에 중지됩니다. 호버 애니메이션은 이벤트 기반이며 지정된 이벤트(이 경우 마우스오버)가 활성화된 동안에만 실행되기 때문입니다.

전체 애니메이션을 강제로 적용할 수는 없나요?

안타깝게도 CSS3 애니메이션이 트리거 이벤트를 지나 계속되도록 강제하는 것은 CSS만으로는 불가능합니다. 사양은 이 시나리오에 대한 간단한 솔루션을 제공하지 않습니다.

JavaScript로 경험 향상

이러한 제한을 해결하기 위해 JavaScript를 통합하여 호버 애니메이션. 애니메이션을 클래스로 추가하고 애니메이션이 완료되면 제거함으로써 마우스 위치에 관계없이 전체 실행을 보장할 수 있습니다.

JavaScript 코드 구현

다음 JavaScript 코드는 문제를 해결합니다.

$(".box").bind("webkitAnimationEnd mozAnimationEnd animationend", function(){
  $(this).removeClass("animated")  
})

$(".box").hover(function(){
  $(this).addClass("animated");        
})
로그인 후 복사

이 스크립트에서 애니메이션은 클래스("animated")로 적용되고 애니메이션이 끝나면 제거되어 마우스가 요소를 떠난 후에도 전체 반복이 완료될 수 있습니다.

결론

순수한 CSS가 애니메이션을 적용할 수 없는 것은 사실입니다. 트리거 이벤트 이후 완료되면 JavaScript 통합은 이 문제를 해결하기 위한 유연하고 효과적인 솔루션을 제공합니다. CSS 애니메이션과 JavaScript의 이벤트 처리 기능을 결합하여 특정 요구 사항을 충족하는 반응적이고 매력적인 애니메이션을 만들 수 있습니다.

위 내용은 CSS3 호버 애니메이션이 완전히 완료되도록 하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿