홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
[jQuery] animate()에서 stop()의 중요성
6년 전
jQuery로 애니메이션을 구현할 때 흔히 만나게 되는 문제가 하나 있다. 바로 애니메이션 큐(queue) 이다.


예를 들어, 네비게이션 메뉴에 마우스가 오면 애니메이션이 동작하게 코딩이 된 경우, 마우스를 여러번 움직였을 때, 이전 애니메이션이 멈추기 전까지 마지막 애니메이션이 동작하지 않는 현상이 바로 애니메이션 큐로 인해 발생하는 문제다.


이러한 문제가 일어나는 이유는 이벤트가 일어날 때마다 큐를 만들기 때문에 이들이 순차적으로 진행되면서 '원하지 않는' 효과가 나타나는 것이다.

사실 말로는 표현이 어려운데 아래 예제를 보면 바로 알 수 있다.
$(".nostop li").hover(
  function () {
      $(this).animate({width:"200px"},500);
  },
   function () {
    $(this).animate({width:"80px"},500);
  }
);

//animate with stop()
$(".stop li").hover(
  function () {
      $(this).stop().animate({width:"200px"},500);
  },
   function () {
    $(this).stop().animate({width:"80px"},500);
  }
);
div {
    font: 12px black;
    margin: 40px 0 10px 0;
}

li{
    width:80px;
    height:40px;
    background:#444;
    margin-bottom:10px;
}

.stop li{
    background:#000;
}
<div>기존 이벤트에 대한 처리가 안되어 있는 경우</div>
<ul class="nostop">
    <li></li>
    <li></li>
    <li></li>
</ul>

<div>기존 이벤트에 대한 처리가 되어 있는 경우</div>
<ul class="stop">
    <li></li>
    <li></li>
    <li></li>
</ul>

<div>각 항목에 마우스를 올려놓기만 했을 때는 차이가 드러나지 않는다.<br/><br/>마우스를 위아래로 여러차례 빠르게 움직여보면 기존 애니메이션 이벤트에 대한 처리를 해준 것과 해주지 않은 차이가 드러난다.</div>

위의 예제를 보면 두 가지 케이스가 나온다. 위의 경우 마우스를 여러번 위아래로 움직이면 움직인 횟수만큼 바 애니메이션이 반복되는 것을 볼 수 있다. 반면 아래의 경우 마우스를 올려놓은 바에서만 애니메이션이 동작한다.


아래와 같이 기존 애니메이션을 중단하고 현재 애니메이션만 보여주기 원할 때는 jQuery가 제공하는 .stop() 메서드 하나만 써도 한번에 해결된다.



$(".trigger-element").hover(function() {
                $(this).stop().animate({ width: "100px"}, 500);
        }, function() {
                $(this).stop().animate({ width: "80px" }, 500);
        });


.stop() 이 호출되면 현재 동작하고 있는 애니메이션은 즉시 동작이 중단된다. 그리고 큐잉되어 있는 것 대신에 다음 동작이 즉시 수행된다. 하지만 .stop()은 애니메이션에 대해서만 동작하기 때문에 다른 종류의 큐를 중단하고 싶다면, .clearQueue() 를 대신 사용해야 한다.
추천추천 : 234 추천 목록
번호 제목
3,036
 PHP 함수 정리
3,035
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
3,034
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.