css3技术

用JavaScript控制CSS Animations(动画)和Transitions(过渡)

字号+ 作者:H5之家 来源:H5之家 2015-09-13 18:17 我要评论( )

用JavaScript控制CSS Animations(动画)和Transitions(过渡)

有时候WEB开发人员认为CSS的动画比JavaScript的动画更难理解。虽然CSS动画有其局限性,但它的性能比大多数JavaScript库更加高效,因为它可以借助硬件加速啊!其效果绝对可以超出我们的预期。

CSS animations和transitions再加上点JavaScript就可以实现硬件加速动画,而且其交互效果比大多数JavaScript库更高效。

So,让我们快点开始吧!小伙伴们都等不及了!

注意:Animations(动画)和Transitions(过渡)是不同的

CSS Transitions(过渡)被应用于元素指定的属性变化时,该属性经过一段时间逐渐的过渡到最终需要的值;而CSS Animations(动画)只是在应用时执行之前定义好的操作,它提供更细粒度的控制。

在这篇文章中,我们将分别针对上述内容进行讲解。

控制CSS Transition(过渡)

在编程论坛中,关于transition(过渡)的触发和暂停有无数的疑问。使用JavaScript可以很容易的解决这些疑问。

触发元素的transiton(过渡),切换元素的类名可以触发该元素的transition(过渡)

暂停元素的transition(过渡), 在你想要暂停过渡点,用getComputedStyle和getPropertyValue获取该元素相应的CSS属性值,然后设置该元素的对应的CSS属性等于你刚才获取到的CSS属性值。

以下是该方法的一个例子。

执行效果:

同样的技术可以用在更高级的方法上。下面的例子也是通过改变类名来触发元素的transition(过渡),但这次可以跟踪当前的缩放率。

执行效果:

注意我们这次改变的是background-size的值。有许多不同的CSS属性可以应用到过渡和动画中,这些属性通常具有数值或颜色值。关于CSS transitions(过渡),Rodney Rehm也写了一篇非常不错的文章,这里可以访问到。

使用CSS“回调函数”

一些最有用但鲜为人知javascript技巧,就是利用监听Dom事件控制CSS transitions(过渡)和animations(动画)。如:与animations(动画)相关的animationEnd,animationStart和animationIteration;与transitions(过渡)相关的transitonEnd。你可能已经猜到它们是做什么的。这些动画事件分别是在元素的动画结束时,开始时,或者完成一次迭代时触发。

目前使用这些事件还需要添加浏览器前缀,所以在这个演示中,我们使用由Craig Buckler开发的叫PrefixedEvent的方法。该方法的参数有element(元素),type(类型)和callback(回调)来实现跨浏览器的兼容。这里是他的一篇文章。这里是另一篇关于通过判断动画名称来判断触发哪个事件。

这个演示想实现当鼠标悬浮时停止动画,并放大心型图案。

执行效果:

纯CSS版本在鼠标悬停时会跳一下,除非你在恰当的时机鼠标移上去,不然它会在扩大到最终悬停状态之前先跳到一个特定状态。JavaScript版本就非常流畅,它在应用新的放大状态之前先让动画完成,这样鼠标悬停时就不会跳动。

控制CSS Animation(动画)

就像我们刚刚了解到的,我们可以看到与元素动画相关的事件:animationStart,animationIteration,animationEnd。但是如果我们想改变CSS animation(动画)执行过程中的动画,还需要一点技巧!

animation-play-state属性
当你想在动画执行过程中暂停,并且接下来让动画接着执行。这时CSS的animation-play-state属性是非常有用的。你可以可以通过JavaScript像这样更改CSS(注意你的前缀):

  • element.style.webkitAnimationPlayState = "paused";
  • element.style.webkitAnimationPlayState = "running";

    复制代码

    然而当使用animation-play-state让CSS 动画暂停时,动画中的元素变形也会以相同的方式被阻止。你不能使这种变形暂停在某个状态,使它变形,使它恢复,更不用期望它能从新的变形状态中恢复到流畅运行。为了实现这些控制,我们需要做一些更复杂的工作。

    获取当前keyvalue的百分比

    不幸的是,在这个阶段没有办法获得当前CSS动画关键帧的“完成百分比”。最好的获取近似值的方法是使用setInterval 函数在动画过程中迭代100次。它的本质是:动画持续的时间(单位是毫秒)/100。例如,如果动画时长4秒,则得到的setInterval的执行时间是每40毫秒(4000 / 100)。

    这种做法很不理想,因为函数实际运行频率要远少于每40毫秒。我发现将它设为39毫秒更准确。但这个也不是好实现,因为它依赖于浏览器,并非所有浏览器下都能得到很完美效果。

    获取当前动画的CSS属性值

    在理想的情况下,我们选择一个使用CSS动画的元素,删除该元素当前动画再给它添加个新的动画,让它可以从当前状态开始新的动画。但是现实情况却很复杂。


    下面我们就有一个演示,用来测试获取和改变CSS动画”中间流”的技术。该动画让一个元素沿一个圆形路径移动,起始位置在圆形的顶部中心(或称为“十二点”)位置。当按钮被单击时,元素的起始位置变成元素当前移动到的位置。元素会沿着之前相同的路径继续移动,只是现在“起始”的位置变成了你按下按钮时元素移动到的位置。通过在动画的第一关键帧把元素的颜色变成红色,来表示元素动画起始点位置发生了改变。

    执行效果:
    相同的概念用在StackOverflow的这个例子中。

    我们需要很深入才能完成!我们要进入的样式表本身找到原有动画。

    你可以用document.styleSheets来获取与页面关联的样式表的集合,然后通过for循环取得具体的样式表。以下是如何使用JavaScript来找到一个特定动画值的CSSKeyFrameRules对象:

  • function findKeyframesRule(rule){
  • var ss = document.styleSheets;
  • for(var i = 0;i < ss.length;++i){
  • for(var j = 0;j<ss[i].cssRules.length;++j){
  • if(ss[i].cssRules[j].type == window.CSSRule.WEBKIT_KEYFRAMES_RULE && ss[i].cssRules[j].name == rule){
  • return ss[i].cssRules[j];
  • }
  • }
  • }
  • return null;
  • }

    复制代码

    我们一旦调用上面的函数(例如 var keyframes= findKeyframesRule(anim)),就可以通过keyframes.cssRules.length获得该对象的动画长度(这个动画中关键帧的总数量)。然后使用JavaScript的方法把获得到的每个关键帧值上的“%”过滤掉,这样JavaScript就可以把这些值作为数字使用。

     

  • 1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    • HTML CSS网页基础开发教程第1讲01

      HTML CSS网页基础开发教程第1讲01

      2015-10-02 16:42

    • HTML CSS网页基础开发教程第1讲02

      HTML CSS网页基础开发教程第1讲02

      2015-10-02 16:42

    • HTML CSS网页基础开发教程第1讲03

      HTML CSS网页基础开发教程第1讲03

      2015-10-02 16:42

    • HTML CSS网页基础开发教程第1讲04

      HTML CSS网页基础开发教程第1讲04

      2015-10-02 16:42

    网友点评