자바스크립트를 통해 CSS 애니메이션을 제어하는 방법에 대해 알아보자.
먼저 다음과 같은 엘리먼트가 있다고 생각해 보자.
<style>
.box{
width:30px;
height:30px;
background:salmon;
position:absolute;
left:0;
top:0;
transition:1s;
}
</style>
<div class="box"></div>
아래 e.clientX
와 e.cilentY
에는 현재 클릭한 윈도우 상의 좌표값을 반환한다.
const box= document.querySelector('box');
window.addEventListener("click, function(e){
console.log(e.clientX, e.clientY);
box.style.transform = 'translate(' +e.clientX + 'px,' + e.clientY + 'px)';
});
여기서 만약 box를 position:absolute
로 띄우지 않으면 이 window가 가지는 마진값에 영향을 받기 때문에, 정확히 내가 클릭한 정확한 위치로 공이 움직이지 않는다.
reset css
를 사용하거나 position: absolute
를 사용하자.
그럼에도 불구하고 엘리먼트의 기준값은 왼쪽 위가 기본이기 때문에 이를 가운데 정렬을 할 방법이 필요하다.
- 요소에 margin을 요소가 가지는 높이와 너비의 절반을 준다. (-15px)
- e.clientX와 Y에 요소의 너비와 높이 값의 절반만큼 준다.
transitionend
는 트랜지션 이벤트가 끝났을 때 동작하는 이벤트이다. 이와 반대인 transitionstart
가 있는데 잘 안써서 넘어감.
위 코드에 다음 코드들을 추가한다.
.box.end{
background:tan;
}
box.addEventListener('transitionend', function(e){
box.classList.add('end');
console.log(e.e.apsedTime); // transition delay time이 찍힌다.
})
'front-end > javascript' 카테고리의 다른 글
[javascript] StopWatch를 통해 보는 시간지연함수 (0) | 2019.09.04 |
---|---|
자바스크립트 AJAX (1/2) , XMLHttpRequest 그리고 HTTP METHOD (0) | 2019.08.28 |
[javascript] Web Storage 웹 스토리지와 쿠키의 개념과 사용법 (0) | 2019.08.24 |
Javascript 동기와 비동기 callback부터 async&await (1) | 2019.08.23 |
Javascript 이벤트 버블링, 위임 target과 currentTarget의 차이 (0) | 2019.08.22 |
댓글