首页 >web前端 >js教程 >如何使用 jQuery 检测 CSS3 转换和动画的结束?

如何使用 jQuery 检测 CSS3 转换和动画的结束?

Patricia Arquette
Patricia Arquette原创
2024-11-04 06:46:30299浏览

How to Detect the End of CSS3 Transitions and Animations with jQuery?

利用 CSS3 转换:使用 jQuery 检测完成

使用 CSS3 转换为元素设置动画时,有必要知道它们结束的准确时刻执行后续操作。与 jQuery 动画不同,CSS3 过渡没有内置完成回调。

捕获过渡结束事件

为了检测过渡的结束,jQuery 提供了以下功能脚本:

<code class="javascript">$("#someSelector").bind("transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd", function(){ ... });</code>

对于动画,可以使用类似的方法:

<code class="javascript">$("#someSelector").bind("animationend webkitAnimationEnd oAnimationEnd MSAnimationEnd", function(){ ... });</code>

通过传递所有带前缀的事件字符串,此脚本将在多个浏览器上运行。

使用 .one() 进行单次触发

为了确保事件处理程序仅触发一次,您可以使用 jQuery 的 .one() 方法而不是 .bind():

<code class="javascript">$("#someSelector").one("transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd", function(){ ... });

$("#someSelector").one("animationend webkitAnimationEnd oAnimationEnd MSAnimationEnd", function(){ ... });</code>

弃用和现代方法

jQuery 的 .bind() 方法现已弃用。首选方法是 .on(),它与 ​​.off() 结合使用。这是一个示例:

<code class="javascript">$("#someSelector")
.on("animationend webkitAnimationEnd oAnimationEnd MSAnimationEnd",
 function(e){
    // do something here
    $(this).off(e);
 });</code>

此方法确保回调函数仅执行一次。

以上是如何使用 jQuery 检测 CSS3 转换和动画的结束?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn