css3打开网页事件,css3动画事件—webkitAnimationEnd与计时器time事件

用css3的animation完成一个动画,当只有这个动画完成时才执行令一个事件,比如让动画保持在终止的状态或其他一些事件。我们该怎么办呢。

第一种方法:

用计时器,设定一个和动画时长一样的time,过time事件去执行这个函数。

setTimeout(function(){ },time);

第二种方法:

当-webkit-animation动画结束时有一个webkitAnimationEnd事件,只要监听这个事件就可以了。

例子:

复制代码代码如下:

webkitAnimationEnd

#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)}

}

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);

拓展:

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,也仅仅有这一个事件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值