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 box-shadow阴影(外阴影与外发光)图示讲解
Aug 11 HTML / CSS
通过css3动画和opacity透明度实现呼吸灯效果
Aug 09 HTML / CSS
css3实现冲击波效果的示例代码
Jan 11 HTML / CSS
HTML5使用DOM进行自定义控制示例代码
Jun 08 HTML / CSS
基于html5实现的图片墙效果
Oct 16 HTML / CSS
基于MUI框架使用HTML5实现的二维码扫描功能
Mar 01 HTML / CSS
HTML5中的websocket实现直播功能
May 21 HTML / CSS
怎样实现H5+CSS3手指滑动切换图片的示例代码
May 05 HTML / CSS
html5 外链式实现加减乘除的代码
Sep 04 HTML / CSS
如何给HTML标签中的文本设置修饰线
Nov 18 HTML / CSS
HTML中的表单Form实现居中效果
May 25 HTML / CSS
纯CSS打字动画的实现示例
Aug 05 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 从一个数组中随机的取出若干个不同的数实例
2016/12/31 PHP
PHP实现的简单对称加密与解密方法实例小结
2017/08/28 PHP
在 Laravel 6 中缓存数据库查询结果的方法
2019/12/11 PHP
JavaScript初学者需要了解10个小技巧
2010/08/25 Javascript
TinyMCE 新增本地图片上传功能
2010/11/05 Javascript
UpdatePanel和Jquery冲突的解决方法
2013/04/01 Javascript
JavaScript实现单击下拉框选择直接跳转页面的方法
2015/07/02 Javascript
辨析JavaScript中的Undefined类型与null类型
2016/05/26 Javascript
javascript入门之数组[新手必看]
2016/11/21 Javascript
JS实现重新加载当前页面或者父页面的几种方法
2016/11/30 Javascript
JS实现点击Radio动态更新table数据
2017/07/18 Javascript
Vue如何从1.0迁移到2.0
2017/10/19 Javascript
详解vue-cli之webpack3构建全面提速优化
2017/12/25 Javascript
详解基于vue-cli配置移动端自适应
2018/01/13 Javascript
微信小程序中this.data与this.setData的区别详解
2018/09/17 Javascript
详解mpvue scroll-view自动回弹bug解决方案
2018/10/01 Javascript
javascript json对象小技巧之键名作为变量用法分析
2019/11/11 Javascript
[01:03:27]NAVI vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python日志模块logging简介
2015/04/13 Python
Python中字符串的处理技巧分享
2016/09/17 Python
Python MySQL数据库连接池组件pymysqlpool详解
2017/07/07 Python
python实现五子棋小游戏
2020/03/25 Python
pyqt5实现登录界面的模板
2020/05/30 Python
python使用Plotly绘图工具绘制柱状图
2019/04/01 Python
python3中eval函数用法使用简介
2019/08/02 Python
美国摄影爱好者购物网站:Focus Camera
2016/10/21 全球购物
嘻哈珠宝品牌:KRKC&CO
2020/10/19 全球购物
质量安全标语
2014/06/07 职场文书
幼儿园门卫岗位职责范本
2014/07/02 职场文书
个人党性分析材料
2014/12/19 职场文书
捐助倡议书
2015/01/19 职场文书
小学教师工作总结2015
2015/04/07 职场文书
三好学生竞选稿范文
2019/08/21 职场文书
php 获取音视频时长,PHP 利用getid3 获取音频文件时长等数据
2021/04/01 PHP
《游戏王:大师决斗》将推出新卡牌包4月4日上线
2022/03/31 其他游戏
V Rising 服务器搭建图文教程
2022/06/16 Servers