Javascript GSAP在不同的时间线上完成不同的功能

Javascript GSAP在不同的时间线上完成不同的功能,javascript,animation,gsap,scrollmagic,Javascript,Animation,Gsap,Scrollmagic,首先,我是GSAP和ScrollMagic的新手,所以如果我在这里问了一个愚蠢的问题,请原谅我。我一直在网上搜索,但没有找到问题的正确答案 无论如何,我试图创建一个时间线,在每个“to”函数完成时,将使用特定参数调用外部函数 var controller = new ScrollMagic.Controller(); var timeline = new TimelineLite(); var div = $('div'); timeline.to(div, 0.5, { opacity

首先,我是GSAP和ScrollMagic的新手,所以如果我在这里问了一个愚蠢的问题,请原谅我。我一直在网上搜索,但没有找到问题的正确答案

无论如何,我试图创建一个时间线,在每个“to”函数完成时,将使用特定参数调用外部函数

var controller = new ScrollMagic.Controller();
var timeline = new TimelineLite();
var div = $('div');

timeline.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay(0)
}, "part-1")

.to(div, 0.5, {
   opacity: 1,
   onComplete: toggleOverlay(1)
}, "part-2")

.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay(2)
}, "part-3");

var scene = new ScrollMagic.Scene({
   triggerElement: "#trigger-event",
   duration: 500
})
.setTween(timeline)
.addTo(controller);

function toggleOverlay(i){
   console.log(i);
}
此处发生的情况:一旦滚动位置达到“触发事件”,将调用时间线。随后,将根据触发事件之后和结束(持续时间)之前的滚动位置调用“.to”函数

我在这里面临的问题是,在页面加载时直接调用onComplete函数。这可能与“.setTween(timeline)”有关,因为我可以想象它会加载到整个timeline中

我的问题的解决方案是什么,或者什么是好的替代方法

编辑:这里有一个JSFIDLE:

谢谢你,
Enzio

您已经使用括号
()
立即调用了函数。阅读答案,更好地理解将函数分配给变量和实际立即执行函数之间的区别

在GSAP中,方法是将
triggerOverlay
函数分配给
onComplete
,而不使用括号,如下所示:

...
onComplete: toggleOverlay
...
要接收额外的参数,您有一个名为
onCompleteParams
的东西将它们作为数组传递给,如下所示:

...
onCompleteParams: [0]
...
因此,您的总体代码应该如下所示:

...
timeline.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay,
   onCompleteParams: [0]
}, "part-1")

.to(div, 0.5, {
   opacity: 1,
   onComplete: toggleOverlay,
   onCompleteParams: [1]
}, "part-2")

.to(div, 0.5, {
   opacity: 0,
   onComplete: toggleOverlay,
   onCompleteParams: [2]
}, "part-3");
...

直到现在我才知道那件事。谢谢:)第一篇总是很好;)