Vue通过JS动态设置-keyFrame实现列表项不同动画

预期效果


对于这个效果,可以选择height配合transition实现,但是css3提供了更流畅的animation,我们就用它来实现这个需求吧

可以看到每一项animation的keyframe都不一样,也就是每一项需要动态使用不同的关键帧。所以主要使用的方法就是动态地往document里插入具有不同关键帧的styleElement,然后在触发动画的地方将animation属性赋给对应的元素。

html代码

1
2
3
<div :style="pillarAnimationStyle">
<span>{{ pillar.usedCount }}</span>
</div>

pillarAnimationStyle是该组件的一个data。
pillarHeight也是当前组件的data,表示当前项需要它渲染到的高度。
index代表当前组件的序号,用来区分不同的关键帧

于是在需要触发动画的地方的代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
const style = document.createElement('style');
style.setAttribute('type', 'text/css');
document.head.appendChild(style);

const sheet = style.sheet;
sheet.insertRule(
`@keyframes pillarAnimation` + this.index + `{
from {
height: 0px;
}
to {
height: ` + this.pillarHeight + `px;
}
}`, 0
);
this.pillarAnimationStyle = {
animation: 'pillarAnimation' + this.index + ' .8s forwards',
};

解决!!!

  • Copyright: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.

扫一扫,分享到微信

微信分享二维码
  • Copyrights © 2020-2024 AuroraAksnesOs

请我喝杯咖啡吧~

支付宝
微信