css3动画事件—webkitAnimationEnd与计时器time事件


Posted in HTML / CSS onJanuary 31, 2013

用css3的animation完成一个动画,当只有这个动画完成时才执行令一个事件,比如让动画保持在终止的状态或其他一些事件。我们该怎么办呢。
第一种方法
用计时器,设定一个和动画时长一样的time,过time事件去执行这个函数。
setTimeout(function(){ },time);
第二种方法
当-webkit-animation动画结束时有一个webkitAnimationEnd事件,只要监听这个事件就可以了。
例子:

复制代码
代码如下:

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="@my_programmer">
<title>webkitAnimationEnd</title>
<meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no"/>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="format-detection" content="telephone=no"/>
<style type="text/css">
#div{
width:200px;
height:200px;
background:#f60;
margin:100px auto;
-webkit-transition: all ease 1s;
}
.change{
-webkit-animation: transform 1s 2 ease;
}
@-webkit-keyframes transform {
% { -webkit-transform: scale(1)}
% { -webkit-transform: scale(2)}
% { -webkit-transform: scale(0.5)}
% { -webkit-transform: scale(1)}
}
</style>
</head>
<body>
<div id="div"></div>
<script type="text/javascript">
var tt = document.querySelector('#div');
tt.addEventListener("click", function(){
this.className = 'change';
}, false);
tt.addEventListener("webkitAnimationEnd", function(){ //动画结束时事件
this.className = this.className.replace('change', ' ');
console.log(2);
}, false);
</script>
</body>
</html>

拓展
1、-webkit-animation动画其实有三个事件:
开始事件 webkitAnimationStart
结束事件 webkitAnimationEnd
重复运动事件 webkitAnimationIteration
你可以在上个例子中测试一下这两个事件
复制代码
代码如下:

tt.addEventListener("webkitAnimationStart", function(){ //动画开始时事件
console.log(1);//动画开始时,控制台输出1
}, false);
tt.addEventListener("webkitAnimationIteration", function(){ //动画重复运动时的事件
console.log(3);//第一遍动作完成时,控制台输出3
}, false);

2、css3的过渡属性transition,在动画结束时,也存在结束的事件:webkitTransitionEnd;
注意:transition,也仅仅有这一个事件。
HTML / CSS 相关文章推荐
CSS3轻松实现圆角效果
Nov 09 HTML / CSS
CSS3正方体旋转示例代码
Aug 08 HTML / CSS
一款纯css3实现的响应式导航
Oct 31 HTML / CSS
浅谈CSS3动画的回调处理
Jul 21 HTML / CSS
css3实现元素环绕中心点布局的方法示例
Jan 15 HTML / CSS
Html5剪切板功能的实现代码
Jun 29 HTML / CSS
详解Canvas 实现炫丽的粒子运动效果(粒子生成文字)
Feb 01 HTML / CSS
html5 button autofocus 属性介绍及应用
Jan 04 HTML / CSS
举例详解HTML5中使用JSON格式提交表单
Jun 16 HTML / CSS
HTML5 画布canvas使用方法
Mar 18 HTML / CSS
如何通过 CSS 写出火焰效果
Mar 24 HTML / CSS
聊聊CSS粘性定位sticky案例解析
Jun 01 HTML / CSS
CSS3 制作绽放的莲花采用效果叠加实现
Jan 31 #HTML / CSS
CSS3 制作旋转的大风车(充满童年回忆)
Jan 30 #HTML / CSS
css3简单练习实现遨游浏览器logo的绘制
Jan 30 #HTML / CSS
IE滤镜与CSS3效果(详细整理分享)
Jan 25 #HTML / CSS
使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
Jan 23 #HTML / CSS
纯css3无js实现的Android Logo(有简单动画)
Jan 21 #HTML / CSS
定义css设备类型-Media Queries图表简介及使用方法
Jan 21 #HTML / CSS
You might like
PHP的面试题集,附我的答案和分析(一)
2006/11/19 PHP
浅析Apache中RewriteCond规则参数的详细介绍
2013/06/30 PHP
php中filter函数验证、过滤用户输入的数据
2014/01/13 PHP
可拖动窗口,附带鼠标控制渐变透明,开启关闭功能
2006/06/26 Javascript
jQuery基础知识filter()和find()实例说明
2010/07/06 Javascript
js函数的延迟加载实现代码
2012/10/11 Javascript
jquery等待效果示例
2014/05/01 Javascript
js取模(求余数)隔行变色
2014/05/15 Javascript
jQuery左侧大图右侧小图焦点图幻灯切换代码分享
2015/08/19 Javascript
JS基于面向对象实现的拖拽库实例
2015/09/24 Javascript
jQuery实现的左右移动焦点图效果
2016/01/14 Javascript
JS实现的简单轮播图运动效果示例
2016/12/22 Javascript
nodeJS实现简单网页爬虫功能的实例(分享)
2017/06/08 NodeJs
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
React Form组件的实现封装杂谈
2018/05/07 Javascript
浅谈使用mpvue开发小程序需要注意和了解的知识点
2018/05/23 Javascript
Vue实现调节窗口大小时触发事件动态调节更新组件尺寸的方法
2018/09/15 Javascript
JS highcharts实现动态曲线代码示例
2020/10/16 Javascript
[02:42]2014DOTA2国际邀请赛 三冰专访:我会打到Ti20
2014/07/13 DOTA
详解Python中的Descriptor描述符类
2016/06/14 Python
python处理数据,存进hive表的方法
2018/07/04 Python
使用Python的Dataframe取两列时间值相差一年的所有行方法
2018/07/10 Python
Tensorflow 合并通道及加载子模型的方法
2018/07/26 Python
3分钟学会一个Python小技巧
2018/11/23 Python
利用python提取wav文件的mfcc方法
2019/01/09 Python
Django 日志配置按日期滚动的方法
2019/01/31 Python
python对矩阵进行转置的2种处理方法
2019/07/17 Python
不到20行实现Python代码即可制作精美证件照
2020/04/24 Python
美国时装品牌:Nautica(诺帝卡)
2016/08/28 全球购物
来自世界上最好大学的在线课程:edX
2018/10/16 全球购物
秋季运动会加油稿200字
2014/01/11 职场文书
党员承诺书内容
2014/03/26 职场文书
三月学雷锋月活动总结
2014/04/28 职场文书
英语教育专业自荐信
2014/05/29 职场文书
详解RedisTemplate下Redis分布式锁引发的系列问题
2021/04/27 Redis
SQL基础查询和LINQ集成化查询
2022/01/18 MySQL