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中的clip-path使用攻略
Aug 03 HTML / CSS
实例讲解使用CSS实现多边框和透明边框的方法
Sep 08 HTML / CSS
CSS3近阶段篇之酷炫的3D旋转透视
Apr 28 HTML / CSS
css3实现wifi信号逐渐增强效果实例
Aug 09 HTML / CSS
HTML5 Canvas标签使用收录
Jul 07 HTML / CSS
使用spring mvc+localResizeIMG实现HTML5端图片压缩上传的功能
Dec 16 HTML / CSS
HTML5 背景的显示区域实现
Jul 09 HTML / CSS
Amaze UI 文件选择域的示例代码
Aug 26 HTML / CSS
CSS3 制作的彩虹按钮样式
Apr 11 HTML / CSS
CSS完成视差滚动效果
Apr 27 HTML / CSS
CSS作用域(样式分割)的使用汇总
Nov 07 HTML / CSS
CSS中实现动画效果-附案例
Feb 28 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
shopex主机报错误请求解决方案(No such file or directory)
2011/12/27 PHP
PHP基于openssl实现的非对称加密操作示例
2019/01/11 PHP
PHP函数积累总结
2019/03/19 PHP
解决php扩展安装不生效问题
2019/10/25 PHP
JavaScript函数、方法、对象代码
2008/10/29 Javascript
关于event.cancelBubble和event.stopPropagation()的区别介绍
2011/12/11 Javascript
javascript中with()方法的语法格式及使用
2014/08/04 Javascript
js判断滚动条是否已到页面最底部或顶部实例
2014/11/20 Javascript
在AngularJS中使用jQuery的zTree插件的方法
2016/04/21 Javascript
BootStrap表单控件之复选框checkbox和单选择按钮radio
2017/05/23 Javascript
浅谈vue.js导入css库(elementUi)的方法
2018/03/09 Javascript
JavaScript实现点击出现图片并统计点击次数功能示例
2018/07/23 Javascript
基于Vue中的父子传值问题解决
2020/07/27 Javascript
javascript中正则表达式语法详解
2020/08/07 Javascript
python爬虫常用的模块分析
2014/08/29 Python
实例Python处理XML文件的方法
2015/08/31 Python
Win7下搭建python开发环境图文教程(安装Python、pip、解释器)
2016/05/17 Python
python中学习K-Means和图片压缩
2017/11/20 Python
Python爬虫获取图片并下载保存至本地的实例
2018/06/01 Python
Django 项目布局方法(值得推荐)
2020/03/22 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
2020/03/24 Python
如何提高python 中for循环的效率
2020/04/15 Python
Styleonme中文网:韩国高档人气品牌
2017/06/21 全球购物
软件测试面试题
2014/01/05 面试题
计算机专业毕业生推荐信
2013/11/25 职场文书
英语专业学生个人求职信范文
2014/01/06 职场文书
夏季奶茶店创业计划书
2014/01/16 职场文书
广告业务员岗位职责
2014/02/06 职场文书
学习十八大演讲稿
2014/09/15 职场文书
小学生校园广播稿
2014/09/28 职场文书
顶岗实习协议书
2015/01/29 职场文书
2015年小学二年级班主任工作总结
2015/05/21 职场文书
初中军训感言
2015/08/01 职场文书
创业计划书之青年旅馆
2019/09/23 职场文书
Python实战之实现康威生命游戏
2021/04/26 Python
如何获取numpy array前N个最大值
2021/05/14 Python