Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 웹스크래핑
- vue-cli
- to do list
- 구글CSS
- MariaDB
- css규칙
- 파이썬
- 자기개발
- css rule
- 프레임워크
- 투두리스트
- Vue.js
- 구글스타일가이드
- 로딩UI
- html제거
- 코딩가이드
- 개발회고
- CSS애니메이션
- CSS로딩
- 코딩컨밴션
- javascript
- google style guide
- vueJS
- 자바스크립트
- 뉴스수집
- @keyframes
- vuejs입문
- python
- 코딩규칙
- 스타일가이드
Archives
- Today
- Total
코드공부방
window resize event 텀을 두고 실행하기 (resize end event) 본문
반응형
window resize event 텀을 두고 실행하기 (resize end event)
window resize 이벤트안에 어떠한 코드를 넣으면 매 resize시마다 이 코드가 실행된다. 의도적으로 매 resize마다 코드를 실행해야 하는 경우도 있지만, 그렇지 않은 경우라면 이는 매우 비효율적이고 때에 따라서는 브라우저에 과부하를 줄 수도 있다. 윈도우 리사이즈시 console.log을 찍어보자. 아래 코드를 보자.
//Javascript
window.addEventListener('resize', function(){
console.log('resize event!');
});
//jQuery
$(window).on('resize', function(){
console.log('resize event!');
});
그럼 위처럼 매번 코드를 실행하지 않고 리사이즈 이벤트가 끝난 뒤 코드를 실행하려면 어떻게 해야할까? 바로 setTimeout 메소드를 사용하면 된다. 아래 코드를 보자.
var delay = 300;
var timer = null;
//Javascript
window.addEventListener('resize', function(){
clearTimeout(timer);
timer = setTimeout(function(){
console.log('resize event!');
}, delay);
});
//jQuery
$(window).on('resize', function(){
clearTimeout(timer);
timer = setTimeout(function(){
console.log('resize event!');
}, delay);
});
timer에 setTimeout 메소드로 0.5마다 콘솔을 찍게 해놨는데 0.5초가 지나기전 resize이벤트가 발생되면 계속 timer값이 계속 덮히는 것이다. 즉, 0.5초동안 resize를 하지 않으면 setTimeout안의 코드가 실행되는 것이다.
반응형
'웹퍼블리셔 > JavaScript' 카테고리의 다른 글
window popup 새창(팝업창) 열기, 띄우기 (javascript window.open()) (0) | 2020.02.18 |
---|---|
jQuery(제이쿼리) 동적으로 생성된 요소 이벤트 및 index(인덱스) 가져오기 (0) | 2020.02.10 |
제이쿼리 쿠키(jQuery Cookie) 활용하여 오늘 하루 보지 않기 기능 구현하기 (12) | 2020.02.04 |
lozyload, 미디어 콘텐츠 지연로딩 시키기 (feat. jQuery Lazy) (0) | 2019.09.19 |
스크롤 감지하여 고정메뉴 노출/비노출 처리 이벤트 (9) | 2019.09.04 |
Comments