【CSS、JS】监听transitionend多次触发的原因

现有代码如下,移入红色内容区域触发动画,监听动画触发,但是每次触发控制台会打印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))

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/owo_ovo/article/details/143120517