JavaScript动画事件

news/2024/11/8 9:45:00/

目录

一、animationstart:当CSS动画开始播放时触发。

二、animationend:当CSS动画播放完成时触发。

三、animationiteration:当CSS动画重复播放时触发。

四、transitionstart:当CSS过渡开始时触发。

五、transitionend:当CSS过渡完成时触发。

六、transitioncancel:当CSS过渡被取消时触发。


JavaScript提供了一些动画相关的事件,可以用于控制和监听动画的执行过程。以下是一些常见的JavaScript动画事件:

一、animationstart:当CSS动画开始播放时触发。

动画事件animationstart在CSS动画开始播放时触发,它可以用于执行一些初始化操作或添加额外的效果。下面是一个简单的例子,演示了如何使用animationstart事件:

<!DOCTYPE html>
<html>
<head><title>Animation Start Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;position: absolute;left: 0;top: 0;animation: slide-in 2s;}@keyframes slide-in {0% {left: -100px;}100% {left: 200px;}}</style><script>var box = document.querySelector('.box');box.addEventListener('animationstart', function() {// 在动画开始时执行的操作console.log('Animation started!');});</script>
</head>
<body><div class="box"></div>
</body>
</html>

在上面的例子中,我们定义了一个名为slide-in的CSS动画,它使元素从左侧移动到右侧。当动画开始播放时,animationstart事件会被触发,回调函数会在控制台打印出一条消息"Animation started!"。

二、animationend:当CSS动画播放完成时触发。

动画事件animationend在CSS动画播放完成时触发,它可以用于在动画结束后执行一些操作或处理后续逻辑。下面是一个简单的例子,演示了如何使用animationend事件:

<!DOCTYPE html>
<html>
<head><title>Animation End Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;position: absolute;left: 0;top: 0;animation: slide-in 2s;}@keyframes slide-in {0% {left: -100px;}100% {left: 200px;}}</style><script>var box = document.querySelector('.box');box.addEventListener('animationend', function() {// 在动画结束时执行的操作console.log('Animation ended!');// 可以在这里添加后续的逻辑处理});</script>
</head>
<body><div class="box"></div>
</body>
</html>

在上面的例子中,我们定义了一个名为slide-in的CSS动画,它使元素从左侧移动到右侧。当动画播放完成时,animationend事件会被触发,回调函数会在控制台打印出一条消息"Animation ended!"。

使用时可以根据具体的需求,在animationend事件的回调函数中执行适当的操作,比如改变元素的样式、添加后续的动画效果等。这样可以在动画结束后进行一些操作,实现更丰富的交互或处理后续的逻辑。

三、animationiteration:当CSS动画重复播放时触发。

动画事件animationiteration在CSS动画每次重复播放时触发,它可以用于监听动画的循环并执行相应的操作。下面是一个简单的例子,演示了如何使用animationiteration事件:

<!DOCTYPE html>
<html>
<head><title>Animation Iteration Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;position: absolute;left: 0;top: 0;animation: rotate 2s infinite;}@keyframes rotate {0% {transform: rotate(0deg);}100% {transform: rotate(360deg);}}</style><script>var box = document.querySelector('.box');box.addEventListener('animationiteration', function() {// 在动画每次循环时执行的操作console.log('Animation iteration!');// 可以在这里添加相应的操作或逻辑});</script>
</head>
<body><div class="box"></div>
</body>
</html>

在上面的例子中,我们定义了一个名为rotate的CSS动画,它使元素沿着中心点顺时针旋转360度。通过将infinite作为动画的animation-iteration-count属性值,使动画无限循环播放。每次动画循环时,animationiteration事件会被触发,回调函数会在控制台打印出一条消息"Animation iteration!"。

可以根据具体的需求,在animationiteration事件的回调函数中执行适当的操作,比如改变元素的样式、添加其他动画效果等。这样可以在动画每次循环时执行相应的操作,实现更灵活和动态的效果。

四、transitionstart:当CSS过渡开始时触发。

动画事件transitionstart在CSS过渡开始时触发,可以用于监听过渡的开始并执行相应的操作。下面是一个简单的例子,演示了如何使用transitionstart事件:

<!DOCTYPE html>
<html>
<head><title>Transition Start Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;transition: width 2s;}</style><script>var box = document.querySelector('.box');box.addEventListener('transitionstart', function() {// 过渡开始时执行的操作console.log('Transition started!');// 可以在这里添加相应的操作或逻辑});</script>
</head>
<body><div class="box"></div>
</body>
</html>

在上面的例子中,我们定义了一个元素.box,当它的宽度发生变化时会触发过渡效果。通过设置transition属性为width 2s,将宽度变化的过渡时间设置为2秒。当过渡开始时,transitionstart事件会被触发,回调函数会在控制台打印出一条消息"Transition started!"。

可以根据具体的需求,在transitionstart事件的回调函数中执行适当的操作,比如改变元素的样式、添加其他动画效果等。这样可以在过渡开始时执行相应的操作,实现更灵活和动态的效果。

五、transitionend:当CSS过渡完成时触发。

动画事件transitionend在CSS过渡结束时触发,可以用于监听过渡的完成并执行相应的操作。下面是一个简单的例子,演示了如何使用transitionend事件:

<!DOCTYPE html>
<html>
<head><title>Transition End Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;transition: width 2s;}</style><script>var box = document.querySelector('.box');box.addEventListener('transitionend', function() {// 过渡结束时执行的操作console.log('Transition ended!');// 可以在这里添加相应的操作或逻辑});function changeWidth() {box.style.width = '200px';}</script>
</head>
<body><div class="box"></div><button onclick="changeWidth()">Change Width</button>
</body>
</html>

在上面的例子中,我们定义了一个元素.box,当点击按钮时会改变其宽度。通过设置transition属性为width 2s,将宽度变化的过渡时间设置为2秒。当过渡结束时,transitionend事件会被触发,回调函数会在控制台打印出一条消息"Transition ended!"。

点击页面上的"Change Width"按钮,会触发changeWidth()函数,将.box元素的宽度从初始值100px变为200px。随后,过渡效果会开始,并在2秒后完成。当过渡结束时,transitionend事件会被触发,回调函数会在控制台打印出相应的消息。

可以根据具体的需求,在transitionend事件的回调函数中执行适当的操作,比如添加其他动画效果、切换元素的样式等。这样可以在过渡完成时执行相应的操作,实现更灵活和动态的效果。

六、transitioncancel:当CSS过渡被取消时触发。

动画事件transitioncancel在CSS过渡被取消时触发,可以用于监听过渡被中止的情况并执行相应的操作。下面是一个简单的例子:

<!DOCTYPE html>
<html>
<head><title>Transition Cancel Event Example</title><style>.box {width: 100px;height: 100px;background-color: red;transition: width 2s;}</style><script>var box = document.querySelector('.box');box.addEventListener('transitioncancel', function() {// 过渡被取消时执行的操作console.log('Transition cancelled!');// 可以在这里添加相应的操作或逻辑});function cancelTransition() {box.style.transition = 'none';}function startTransition() {box.style.transition = 'width 2s';box.style.width = '200px';}</script>
</head>
<body><div class="box"></div><button onclick="cancelTransition()">Cancel Transition</button><button onclick="startTransition()">Start Transition</button>
</body>
</html>

在上面的例子中,我们定义了一个元素.box,并为其设置了一个宽度变化的过渡效果。通过设置transition属性为width 2s,将宽度变化的过渡时间设置为2秒。当调用startTransition()函数时,.box元素的宽度会从初始值100px变为200px,并且过渡效果会开始。

我们还定义了一个"Cancel Transition"按钮,点击该按钮会调用cancelTransition()函数。该函数会将.box元素的过渡效果取消,通过将transition属性设置为none,从而中止过渡。

当过渡被取消时,transitioncancel事件会被触发,回调函数会在控制台打印出一条消息"Transition cancelled!"。

可以根据具体的需求,在transitioncancel事件的回调函数中执行适当的操作,比如回滚到初始状态、修改元素的样式等。这样可以在过渡被中止时执行相应的操作,实现更灵活和可控的效果。


http://www.ppmy.cn/news/97842.html

相关文章

Hbase学习笔记

1 HBase介绍 (1) HBase是什么 HBase是一个开源的非关系型分布式、实时数据库(Nosql)&#xff0c;运行于HDFS文件系统之上&#xff0c;因此key容错地存储海量稀疏的数据。 海量稀疏就是说不能保证每一个key它的列都有value。 关系型数据库&#xff1a;mysql、oracle 非关系…

SpringMVC bean加载控制 -- SpringMVC入门保姆级教程(二)

文章目录 前言二、SpringMVC bean 加载控制1.bean加载控制2.添加Spring开发环境3.SpringMVC bean加载控制4.SpringMVC bean控制相关知识点 总结 前言 为了巩固所学的知识&#xff0c;作者尝试着开始发布一些学习笔记类的博客&#xff0c;方便日后回顾。当然&#xff0c;如果能…

华为OD机试真题B卷 Java 实现【食堂供餐】,附详细解题思路

一、题目描述 某公司员工食堂以盒饭的方式供餐。 为将员工取餐排队时间降为0&#xff0c;食堂的供餐速度必须要足够快。 现在需要根据以往员工取餐的统计信息&#xff0c;计算出一个刚好能达到排队时间为0的最低供餐速度。 即&#xff0c;食堂在每个单位时间内必须至少做出…

python基础----环境搭建-----01

一 python介绍 1.1 Python 特点 Python 是完全面向对象的语言。函数、模块、数宁、宁符串都是对象&#xff0c;在 Python 中一切皆对象。完全支持继承、重载、多重继承。支持重载运算符&#xff0c;也支持泛型设计。Python 拥有一个强大的标准库&#xff0c;Python 语言的核心…

杨立昆:科学之路读书笔记2

杨立昆&#xff1a;科学之路读书笔记2 人工智能的低谷人工智能无所不能吗&#xff1f;谁将从AI人工智能革命中获益结语 一起学AI系列博客&#xff1a;目录索引 人工智能的低谷 上回分享了读书缘由&#xff0c;杨立昆的背景及其对人工智能的研究看法&#xff0c;这回分享他如何…

cortex-m3软件断点/单步执行的实现机制

一.软件断点 软件断点设置后&#xff0c;断点处的代码如果是存放在SRAM中&#xff0c;相应的一条指令&#xff08;C语言中的一行代码可能对应多条处理器指令&#xff09;会被调试器&#xff08;debugger&#xff09;替换成cortex-m3的BKPT指令&#xff0c;当程序运行到这一BKPT…

从0到1接入钉钉消息通知

前段时间给项目接入监控告警&#xff0c;消息通知渠道选了钉钉。预算的原因内部办公刚从飞书转回钉钉&#xff0c;飞书消息通知之前就有一套了&#xff0c;测试钉钉从应用授权到消息测试花了不少时间。这里记录下从钉钉开放平台权限申请到消息接收全流程&#xff0c;给后面有同…

【Android工具】免费好用无广告安卓手机解压缩软件工具:ZArchiver

微信关注公众号 “DLGG创客DIY” 设为“星标”&#xff0c;重磅干货&#xff0c;第一时间送达。 前言 压缩工具在日常工作和生活中很常用&#xff0c;不光可以减小文件大小&#xff0c;还可以将多个文件进行打包&#xff0c;方便管理。 当然还有一些其他的特殊功能&#xff0c;…