javascript - GSAP 时间线不同补间上的各种 onComplete 函数

标签 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: 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);
}

这里发生了什么:一旦滚动位置到达“#trigger-event”,时间线就会被调用。随后,将根据触发事件之后和结束(持续时间)之前的滚动位置调用“.to”函数。

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

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

编辑:这是一个 JSFiddle:https://jsfiddle.net/04db5ja5/

谢谢您的问候, 恩齐奥

最佳答案

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

在 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");
...

关于javascript - GSAP 时间线不同补间上的各种 onComplete 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34331297/

相关文章:

javascript - Angularjs limitTo 在使用(键,值)时不起作用

javascript - 在 React 中是否可以使用钩子(Hook)来填充由 array.map() 生成的各个输入?

javascript - Jquery 使用计时器制作 div 淡出

android - RecyclerView 和动画中的 notifyItemInserted()

不知道幻灯片数量的CSS3幻灯片

jquery - 管理复杂的 ScrollMagic 代码

javascript - 一个场景中的多个补间

javascript - CORS 与 XMLHttpRequest 不起作用

html - CSS3、HTML 慢动画 'train'

javascript - 如何在某个div上应用动画?