您的位置:首页 > Web前端 > CSS

原生js判断css动画结束 css 动画结束的回调函数

2015-03-09 17:33 591 查看
原文:原生js判断css动画结束css动画结束的回调函数


css3的时代,css3--动画一切皆有可能;

传统的js可以通过回调函数判断动画是否结束;即使是采用CSS技术生成动画效果,JavaScript仍然能捕获动画或变换的结束事件;

transitionend
事件和
animationend
事件标准的浏览器事件,但在WebKit浏览器里你仍然需要使用
webkit
前缀,所以,我们不得不根据各种浏览器分别检测事件

vartransitions={ 'transition':'transitionend', 'OTransition':'oTransitionEnd', 'MozTransition':'transitionend', 'WebkitTransition':'webkitTransitionEnd' }

下面附上源代码:

<!doctypehtml> <html> <head> <metacharset="utf-8"> <title>sufacejs判断css动画是否结束</title> </head> <body> <p>一旦动画或变换结束,回调函数就会触发。不再需要大型类库支持。<br>http://www.webhek.com/css-animation-callback/来源于web骇客</p> <styletype="text/css"> .sample{ width:200px; height:200px; border:1pxsolidgreen; background:lightgreen; opacity:1; margin-bottom:20px; transition-property:opacity; /*transition-duration:.5s;*/ transition-duration:3s; } .sample.hide{ opacity:0; } </style> <divclass="sample">css3动画过度慢慢隐藏(transition-duration:3s;)</div> <p><buttononclick="this.style.display='none';startFade();">慢慢消退,检测结束事件</button></p> <script> (function(){ vare=document.getElementsByClassName('sample')[0]; functionwhichTransitionEvent(){ vart; varel=document.createElement('fakeelement'); vartransitions={ 'transition':'transitionend', 'OTransition':'oTransitionEnd', 'MozTransition':'transitionend', 'WebkitTransition':'webkitTransitionEnd' } for(tintransitions){ if(el.style[t]!==undefined){ returntransitions[t]; } } } vartransitionEvent=whichTransitionEvent(); transitionEvent&&e.addEventListener(transitionEvent,function(){ alert('css3运动结束!我是回调函数,没有使用第三方类库!'); }); startFade=function(){ e.className+='hide'; } })(); </script> </body> </html>

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐