现有代码如下,移入红色内容区域触发动画,监听动画触发,但是每次触发控制台会打印4次
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>test</title>
<style>
#ball {
width: 100px;
height: 100px;
background-color: red;
transition: border-radius 0.3s ease;
}
#ball:hover {
border-radius: 50%;
}
</style>
</head>
<body>
<div id="ball"></div>
<script>
ball.addEventListener('transitionend', function () {
console.log('transitionend');
})
</script>
</body>
</html>
这是因为每一个CSS属性发生变化后都会触发一次,border-radius
是语法糖实际上是4个属性。
可以通过传入配置对象,进行限制监听事件仅触发一次回调。
ball.addEventListener('transitionend', function () {
console.log('transitionend');
},{ once: true })
如果想在鼠标移出时再次触发,就需要手动控制,这里采用防抖实现。
const debounce = (fn, delay) => {
let timer = null;
return function (...args) {
clearTimeout(timer);
timer = setTimeout(() => fn.apply(this, args), delay);
};
}
ball.addEventListener('transitionend', debounce(() => {
console.log('transitionend');
}, 20))