进入 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 不再扮演重要角色, 让你的页面变得更轻巧.
来源: http://www.webhek.com/post/css-animation-callback.html