以下是一个简单的例子,演示如何使用 animationstart 事件:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>animationstart 事件示例</title>
<style>
@keyframes myAnimation {
from {
transform: translateX(0);
}
to {
transform: translateX(200px);
}
}
.animated-element {
width: 50px;
height: 50px;
background-color: lightblue;
animation: myAnimation 2s ease-in-out infinite;
}
</style>
</head>
<body>
<div class="animated-element" onanimationstart="handleAnimationStart()"></div>
<script>
function handleAnimationStart() {
console.log('动画开始播放!');
}
</script>
</body>
</html>
在这个例子中,一个简单的 CSS 动画被定义,并应用到一个 <div> 元素上,该元素有一个 onanimationstart 属性,以在动画开始时触发 handleAnimationStart 函数。在这个函数中,会在控制台输出相应的日志信息。
需要注意的是,animationstart 事件可能会在每次动画迭代开始时触发,因此如果动画是无限循环的,该事件将在每次循环中都被触发。
推荐使用 JavaScript 中的 addEventListener 方法而不是在 HTML 属性中直接使用事件处理程序,以提高代码的可维护性。
转载请注明出处:http://www.pingtaimeng.com/article/detail/4445/HTML