gpt4 book ai didi

javascript - 反转后清除 GSAP TimelineMax 动画

转载 作者:太空宇宙 更新时间:2023-11-04 12:48:31 29 4
gpt4 key购买 nike

基本上我有这样的结构,我的目标是为 4 个 div 设置动画,这样当您点击一个时,另一个会滑出,当您点击容器时,它们会返回到初始位置。

var TL = new TimelineMax;
$('.quater').on('click', function () {
$faders = $('.container').find('.quater').not(this),
$faders.each(function () {
TL.to($(this), 1, {autoAlpha:0, x:50}, 0);
});
});

$('.container').on('click', function () {
TL.reverse();
TL.clear();
});

问题是如果我省略“TL.clear();”如果我输入“TL.clear();”,它将仅对单击的第一个“.quater”div 起作用。动画将不再反转。

最佳答案

jsFiddle .

片段:

var container = document.querySelector('.container');
var items = document.querySelectorAll('.item');
var duration = 0.6;
var ease = Expo.easeOut;
var numItems = items.length;
var i;

container.addEventListener('click', onContainerClicked, false);

for (i = 0; i < numItems; i += 1) {
(function(index){
items[index].timeline = new TimelineMax({ paused: true });
items[index].timeline.fromTo(items[index], duration, { y: 0, autoAlpha: 0.4 }, { y: -104, autoAlpha: 1, ease: ease });
items[index].addEventListener('click', onItemClicked, false);
}(i));
}

function onContainerClicked() { reverseAll(); }

function onItemClicked(e) {
reverseAll();
e.target.timeline.play();
}

function reverseAll() {
for (i = 0; i < numItems; i += 1) { items[i].timeline.reverse(); }
}
html, body {
margin: 0;
padding: 0;
}

.container {
background: #444;
width: 512px;
height: 104px;
}

.item {
float: left;
margin: 2px 0 0 2px;
width: 100px;
height: 100px;
}

.item:nth-child(odd) { background: #0cc; }
.item:nth-child(even) { background: #cc0; }
<script src="//cdnjs.cloudflare.com/ajax/libs/gsap/1.17.0/TweenMax.min.js"></script>
<div class="container"></div>
<div class="item">&nbsp;</div>
<div class="item">&nbsp;</div>
<div class="item">&nbsp;</div>
<div class="item">&nbsp;</div>
<div class="item">&nbsp;</div>

关于javascript - 反转后清除 GSAP TimelineMax 动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26314836/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com