• css3动画事件—webkitAnimationEnd


      用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{
    200px;
    height:200px;
    background:#f60;
    margin:100px auto;
    -webkit-transition: all ease 1s;
    }
    .change{
    -webkit-animation: transform 1s 2 ease;
    }
    @-webkit-keyframes transform {
    0% { -webkit-transform: scale(1)}
    30% { -webkit-transform: scale(2)}
    60% { -webkit-transform: scale(0.5)}
    100% { -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,也仅仅有这一个事件。

  • 相关阅读:
    使用Java+SAP云平台+SAP Cloud Connector调用ABAP On-Premise系统里的函数
    使用Java程序消费SAP Leonardo的机器学习API
    如何在SAP Server Side JavaScript里消费destination
    使用HANA Web-based Development Workbench创建最简单的Server Side JavaScript
    如何用WebIDE打开并运行CRM Fiori应用
    SAP成都研究院的体育故事
    ABAP和Java的destination和JNDI
    使用SAP云平台 + JNDI访问Internet Service
    让SAP云平台上的Web应用使用destination服务
    如何处理SAP HANA Web-Based Development Workbench的403 Forbidden错误
  • 原文地址:https://www.cnblogs.com/duanhuajian/p/2881973.html
Copyright © 2020-2023  润新知