原生js判断css3动画过度(transition)结束 transitionend事件 以及关键帧keyframes动画结束(animation)回调函数 animationEnd

这是transition过度的 结束事件;

至于animation关键帧动画结束,提供了3个api;如下

开始事件 webkitAnimationStart 
结束事件 webkitAnimationEnd 
重复运动事件 webkitAnimationIteration;

原生js判断css3动画过度(transition)结束 transitionend事件 以及关键帧keyframes动画结束(animation)回调函数 animationEnd_第1张图片

 

本文的 demo 主要讲的 是 transition的过度回调函数;

 

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

 

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

 

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

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

 

下面附上源代码:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>suface   js判断css动画是否结束</title>
</head>

<body>

<p>一旦动画或变换结束,回调函数就会触发。不再需要大型类库支持。<br> </p>
<style type="text/css">
.sample {
width: 200px;
height: 200px;
border: 1px solid green;
background: lightgreen;
opacity: 1;
margin-bottom: 20px;
transition-property: opacity;
/*transition-duration: .5s;*/
transition-duration:3s;
}
.sample.hide {
opacity: 0;
}
</style>
<div class="sample">css3动画过度慢慢隐藏(transition-duration:3s;)</div>
<p><button onclick="this.style.display='none';startFade();">慢慢消退,检测结束事件</button></p>
<script>             
 ;(function() {
			var e = document.getElementsByClassName('sample')[0];
			function whichTransitionEvent(){
			var t,
			    el = document.createElement('surface'),
			    transitions = {
			      'transition':'transitionend',
			      'OTransition':'oTransitionEnd',
			      'MozTransition':'transitionend',
			      'WebkitTransition':'webkitTransitionEnd'
			    }

			    for(t in transitions){
			        if( el.style[t] !== undefined ){
			            return transitions[t];
			        }
			    }
			}

			var transitionEvent = whichTransitionEvent();
			transitionEvent && e.addEventListener(transitionEvent, function() {
				alert('css3运动结束!我是回调函数,没有使用第三方类库!');
			});

			startFade = function() {
				e.className+= ' hide';
			}
		})();
</script>
</body>
</html>

//兼容性 详情

原生js判断css3动画过度(transition)结束 transitionend事件 以及关键帧keyframes动画结束(animation)回调函数 animationEnd_第2张图片

另外,注意一下:在js调用中;

transitionend 存在两个bug:

一个是:

如果 transition 中:变换的属性有多个 ;多导致不停的促发该属性  , transition 动画无法停止;

另一个是:

如果 transition 中:变换的属性有多个 ;多导致不停的促发 transitionend  回调函数,需要removeEventListener()。

 

 

本文地址:http://www.cnblogs.com/surfaces/

 

你可能感兴趣的:(transition)