jquery - 忽略初始值的动画 (animation-fill-mode)

标签 jquery css animation css-animations

我做了什么...

我目前正在编写一个脚本,该脚本将在元素进入用户视口(viewport)时对其进行动画处理,就像 WOW.js 一样。

但是,我遇到了一些我打算制作动画的元素的奇怪行为。它不是从关键帧的第一步开始动画,而是忽略未在原始元素上设置的任何样式。

考虑一下:

setTimeout(function() {
  $('#some_element').addClass('animated fade_in_down');
}, 500);
/* The element I intend to animate */
#some_element {
  width: 50px;
  height: 50px;
  background: #000;
  opacity: 0; /* I set the initial opacity */
  /* NOTE - I have not set transform:translateY(-20px); */
}

/* The animation classes */
.animated {
  animation-duration: 1s;
  animation-fill-mode: both /* I think this is the important part */
}

.fade_in_down {
  animation-name: fade_in_down
}

@keyframes fade_in_down {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="some_element">

我的问题...

因此,如果您运行上面的代码片段,您会发现动画按预期运行。比如,它淡入并转换为 20px...

我的问题是,在我的网站上,它忽略了 transform 属性,除非我在原始 #some_element 样式中明确设置它。

除非我执行以下操作,否则我只会看到 opacity 动画:

#some_element {
  width: 50px;
  height: 50px;
  background: #000;
  opacity: 0;
  transform:translateY(-20px); /* I have added the initial transform value */
}

这是为什么?为什么它无需设置初始 transform 值就可以在其他站点上运行?任何人都可以详细说明可能导致这种情况的原因吗?

我正在使用 CSS 缩小器,它会去除 0 之后的 % 符号 @keyframes 规则。这可能是原因吗?去掉%符号是不是无效?

不幸的是,我无法发布我的全部代码,因为这只是一个非常大的网络应用程序的片段。我希望有人可能知道发生了什么,而无需查看我的整个代码...

最佳答案

原因:

问题要么是因为您对 @keyframes 的编码方式规则在你的实际 CSS 文件中(或)因为你的缩小器如何缩小代码。

下面是我可以在您的缩小 CSS 文件中看到的输出 CSS。正如您在 @keyframes 中看到的那样, %0 之后丢失.该百分比是强制性的,因为它不存在,所以 UA 完全忽略了它下设置的属性,因此原始负数 translateY从未应用于它。由于从未应用原始变换,因此它不会向下滑动而只是出现。

来自W3C Specs for Animation : (重点是我的)

Note that the percentage unit specifier must be used on percentage values. Therefore, ‘0’ is an invalid keyframe selector.

opacity有效是因为你有 .reveal-on-scroll这迫使 opacity: 0在元素上。

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both
}
.fade_in_down {
  -webkit-animation-name: fade_in_down;
  animation-name: fade_in_down
}
@-webkit-keyframes fade_in_down {
  0 { /* note the missing % symbol */
    opacity: 0;
    -webkit-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px)
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0)
  }
}
@keyframes fade_in_down {
  0 { /* note the missing % symbol */
    opacity: 0;
    -webkit-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px)
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0)
  }
}

演示:

只是为了演示这一点,我在下面的演示中添加了两个元素,其中一个元素带有 % 的动画。之前 0@keyframes规则和其他没有它的(%)。关键帧写为0%的一个会正常下滑而关键帧写为0的那个就会出现。

setTimeout(function() {
  $('#some_element').addClass('animated fade_in_down');
  $('#some_element2').addClass('animated fade_in_down2');
}, 500);
#some_element,
#some_element2 {
  display: inline-block;
  width: 50px;
  height: 50px;
  background: #000;
  opacity: 0;
}
.animated {
  animation-duration: 1s;
  animation-fill-mode: both
}
.fade_in_down {
  animation-name: fade_in_down
}
@keyframes fade_in_down {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* this is how the minified output in your CSS file is */

.fade_in_down2 {
  animation-name: fade_in_down2
}
@keyframes fade_in_down2 {
  0 {
    opacity: 0;
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="some_element"></div>
<div id="some_element2"></div>


解决方案:

如果您的原始 CSS 中缺少该符号,请添加它。如果缩小器将其删除,请查看如何避免这种情况。不幸的是,我对此知之甚少。

关于jquery - 忽略初始值的动画 (animation-fill-mode),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36130791/

相关文章:

jquery - Datatables 1.10 修改自定义 HTML 参数以发送到服务器

升级到新的 jQuery 版本后 jQuery 将不会返回数据

javascript - 使用 JavaScript 更改 CSS 样式颜色值

iphone - Mapkit 缩放动画

javascript - 加速数字越接近其最大值

javascript - 防止 Webapp 中的额外触摸

php - jquery、css不适用于表格

javascript - 仅在父 div 上悬停效果

html - 使导航折叠

android - 在 kenburnsview 启动画面中添加另一个 textview