홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
운.영.자.1대1.상담

온라이브음악방송
온라이브스토어(앱다운로드)
아리랑가요(무료음악채널)
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
동영상노래방
가사검색

POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
최신 인기가요

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
[jQuery] animate()에서 stop()의 중요성
3년 전
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() 를 대신 사용해야 한다.
추천추천 : 165 추천 목록
번호 제목
3,026
 여러 도메인들 간 쿠키 공유하기
3,025
 태그 사이에 있는 텍스트를 추출
3,024
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,023
 쿠키 생성,가져오기,삭제
3,022
 사용자 함수 모음
3,021
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,020
 [HTML5] <video> - DOM으로 제어하기
3,019
 HTML5 video 태그에서 영상 좌우반전
3,018
 PHP - 특정 태그 및 문자열 추출, 제거
3,017
 [PHP] define과 defined의 차이
3,016
 우클릭 완벽차단 스크립트
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
목록
추억의가요방(가사포함)
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
POP TOP BEST

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.