Study/JavaScript

[JavaScript] 중급 #12 - setTimeout / setInterval

성으니:) 2021. 9. 26. 23:30

 

setTimeout: 일정 시간이 지난 후 함수를 실행

  -  두개의 매개변수를 받음

  -  첫 번째 매개변수는 일정 시간이 지난 후 실행될 함수, 두 번째는 지연될 시간

 

e.g.)         

function fn() {
	console.log(3);
}

setTimeout(fn, 3000); // 3초 후에 숫자 3 출력

 

e.g.) 위 예제와 동일하게 작동함

setTimeout(function() {
	console.log(3);
}, 3000);

 

e.g.)

const tId = function showName(name) {
	console.log(name);
}

setTimeout(showName, 3000, "Angel");
clearTimeout(tId);

  -  setTimeout()의 매개변수를 확인해보면, showName은 실행시킬 함수, 3000delay시간, ‘Angel’showName함수에 들어갈 인수이다.

  -  clearTimeout은 예정된 작업을 제거

 

e.g.) delay = 0 일 때

setTimeout(function() {
	console.log(2);
}, 0);

console.log(1);

  →  1이 먼저 출력되고 2가 출력됨

      현재 실행 중인 스크립트가 종료된 이후에 스케줄링 함수를 실행시키기 때문

      그리고 브라우저는 기본적으로 4ms 이상의 대기 시간이 있음

 

 

setInterval: 일정 시간 간격으로 함수를 반복

function showName(name) {
	console.log(name);
}

const tId = setInterval(showName, 3000, "Angel"); // 3초마다 “Angel” 출력

clearInterval(tId); // 예정된 작업을 제거

       

e.g.)         

let num = 0;

function showTime() {
	console.log(`${num++}초 지났습니다.`);
	
	if(num >3) {
		clearInterval(tId);
	}
}

const tId = setInterval(showTime, 1000);


//→	0초 지났습니다.
//	1초 지났습니다.
//	2초 지났습니다.
//	3초 지났습니다. 출력

 

 

 

 

↓ [코딩앙마] 자바스크립트 중급 강좌 링크

https://www.youtube.com/watch?v=nwk_aNbFEEc