如何用JavaScript探测CSS动画是否已经完成
1个回答
展开全部
进入2014年后,我们这些Web开发者开始慢慢发现需要面对一种困难,就是传统的JavaScript技术开始失效。很多年来我们一直依赖的那些JavaScript技巧技术,在如今CSS3兴起的情况下,很多的特效被浏览器内置的CSS功能替代。以前我们一直需要的一个功能——JS动画中结束时会触发回调函数——现在改用CSS动画后,如何触发这些回调动作?
幸运的是,即使是采用CSS技术生成动画效果,JavaScript仍然能捕获动画或变换的结束事件。下面就是如何实现的!
JavaScript
有一个问题需要说明的问题是浏览器的CSS方言前缀。transitionend事件和animationend事件标准的浏览器事件,但在WebKit浏览器里你仍然需要使用webkit前缀,所以,我们不得不根据各种浏览器分别检测事件。
/* 探测浏览器种类 */
function whichTransitionEvent(){
var t;
var el = document.createElement('fakeelement');
var 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() {
console.log('Transition complete! This is the callback, no library needed!');
});
一旦动画或变换结束,回调函数就会触发。不再需要大型类库支持。
想象一下,如果使用JavaScript实现,你要么使用Jquery这样重量级的程序包,要么是自己手写出一大批代码,现在却是如此简单。动画变换的持续时间,填充方式,延迟属性等都可以使用CSS设置,JavaScript不再扮演重要角色,让你的页面变得更轻巧。
幸运的是,即使是采用CSS技术生成动画效果,JavaScript仍然能捕获动画或变换的结束事件。下面就是如何实现的!
JavaScript
有一个问题需要说明的问题是浏览器的CSS方言前缀。transitionend事件和animationend事件标准的浏览器事件,但在WebKit浏览器里你仍然需要使用webkit前缀,所以,我们不得不根据各种浏览器分别检测事件。
/* 探测浏览器种类 */
function whichTransitionEvent(){
var t;
var el = document.createElement('fakeelement');
var 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() {
console.log('Transition complete! This is the callback, no library needed!');
});
一旦动画或变换结束,回调函数就会触发。不再需要大型类库支持。
想象一下,如果使用JavaScript实现,你要么使用Jquery这样重量级的程序包,要么是自己手写出一大批代码,现在却是如此简单。动画变换的持续时间,填充方式,延迟属性等都可以使用CSS设置,JavaScript不再扮演重要角色,让你的页面变得更轻巧。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询