홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송 메인홈 1대1상담
운.영.자.1대1.상담
온라이브음악방송
온라이브스토어(앱다운로드)
아리랑가요(무료음악채널)
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
자바스크립트 타이머 - setTimeout, setInterval, clearInterval 함수
4년 전
Javascript 를 이용할 때,
1) 종종 특정 함수나 기능을 페이지가 로드되거나 버튼이 클릭되었을 때, 바로 실행하지 않고, 약간의 시간이 지난후에 실행되게 하고 싶은 경우가 있습니다. 또는
2) 특정 함수를 지속적으로 반복하여 실행하고 싶은 경우도 있구요.

예를 들면 특정 정보를 화면에 표시하여 사용자에게 안내하고, 5초 후에 다른 페이지로 이동시키고 싶은 것이라면 위의 첫번째 경우이겠죠?
그리고 10초마다 새로운 정보를 보여주기 위해 페이지의 특정 영역 프레임을 AJAX호출을 통해 지속적으로 갱신해주고 싶은 경우라면 두번째 경우일 것 같구요.

이런 처리를 위해 Javascript는 어떤 함수를 제공하고 있을까요?

바로 setTimeout 과 setInterval 함수입니다.

바로 함수 정의와 사용 방법에 대해 알아 보겠습니다.

1) setTimeout([Function], [Milliseconds])

- 특정 시간 이 후, 단 한번만 특정 함수 또는 코드를 실행시킬 때 사용합니다.
- 2번째 인자의 시간(Milliseconds)이 경과하면 1번째 인자의 함수를 실행합니다.

- 예제 코드
<script type="text/javascript">
$(document).ready(function() {
      ...

setTimeout("ozit_timer_test()", 3000); // 3000ms(3초)가 경과하면 ozit_timer_test() 함수를 실행합니다.

...
});

function ozit_timer_test(){
alert("오즈의 순위왕 블로그로 이동합니다.");
location.href = "http://ozrank.co.kr"; // 오즈의 순위왕 블로그로 이동합니다.
}

</script>


위의 예제코드는 첫번째 인자로 사용되는 함수를 별도로 정의한 후, 해당 함수명을 인자로 setTimeout 함수를 호출하고 있는데, 해당 함수가 다른 곳에 사용되지 않고, 재사용이 필요하지 않은 경우라면 다음의 코드 처럼 함수 정의 자체를 첫번째 인자 내에 구현할 수 있습니다.

참고 : 1000ms 는 1s 입니다. (1000밀리세컨드 = 1세컨드(초))

<script type="text/javascript">
$(document).ready(function() {
      ...

setTimeout(function() {
alert("오즈의 순위왕 블로그로 이동합니다.");
location.href = "http://ozrank.co.kr";
}, 3000); // 3000ms(3초)가 경과하면 이 함수가 실행됩니다.

...
}

</script>

코드가 좀 더 간결해졌습니다.(하지만 사실 가독성은 약간 떨어진 편입니다.)
그리고 단지 해당 코드(함수)는 다른 곳에서 재사용하지 못하고 오직 setTimeout 내에서만 사용됩니다.

이렇게 함수의 이름없이 간결하게 작성된 함수를 익명 함수(Anonymous Function) 라고 합니다.

사실 위와 같은 구현 방법은 Javascript 많이 하신 분들이라면 쉽게 이해하고, 간편하기 때문에 자주 사용하시는 방법이기도 합니다. ㅎㅎ



2) setInterval([Function], [Milliseconds])

- 특정 시간 마다 특정 함수 또는 코드를 실행시킬 때 사용합니다.
- 2번째 인자의 시간(Milliseconds)이 지날때마다 1번째 인자의 함수를 실행합니다.

- 예제 코드
<script type="text/javascript">
var sum = 0;

$(document).ready(function() {
      ...

setInterval("ozit_interval_test()", 5000); // 매 5000ms(5초)가 지날 때마다 ozit_timer_test() 함수를 실행합니다.

...
});

function ozit_timer_test(){ // 이 함수는 5초마다 실행됩니다.
sum += 1; // 매 5초마다 숫자 1을 sum 변수에 더합니다.
}

</script>

위의 setTimer에서와 같이 좀 더 간결한 코드로 작성해보겠습니다.

<script type="text/javascript">
var sum = 0;

$(document).ready(function() {
      ...

setInterval(function() {
sum += 1; // 매 5초마다 숫자 1을 sum 변수에 더합니다.
}, 5000); // 5000ms(5초)가 경과하면 이 함수가 실행합니다.

...
});
</script>


그리고 마지막으로 한가지 더!!

setInterval 함수를 사용하면 매 특정 시간마다 함수가 실행되는데, 이게 페이지가 바뀌거나 리프레시 될때까지 무 한정 실행됩니다.
물론 무한정 실행되어야 하는 페이지도 있겠지만, 어떤 특정 조건이 되었을 때, 더 이상 setInterval이 동작하지 않기 원할 때도 있을 것입니다.
그러면 setInterval이 더 이상 동작하지 않게 할 수는 없을까요?

이 때에는 clearInterval 함수를 사용하면 됩니다. 그리고 setInterval 함수 실행 시, 반드시 return 값 (Timer ID)을 반환 받아서 가지고 있어야 합니다.


3) clearInterval([Timer Id])

<script type="text/javascript">
var timerId = 0;

$(document).ready(function() {

timerId = setInterval("ozit_interval_test()", 5000);

document.getElementById('stop_timer').onclick = function() {    // 인라인 함수
clearInterval(timerId);    // timerId 값을 인자로 입력하여 해당 setInterval 을 종료시킵니다.
}
});
</script>


<span id='stop_timer'>타이머 멈추기</span>



이제 setTImeout 과 setInterval, clearInterval 함수를 쉽게 사용하실 수 있으시겠죠?

그리고 익명함수(Anonymous Function)에 대해서도 간단히 알아 보았습니다.^^
추천추천 : 245 추천 목록
번호 제목
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함수
목록
추억의가요방(가사포함)
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
CDN 추천곡
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
POP TOP BEST

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.