GSAP时间轴上的各种onComplete函数在不同的tweens上
GSAP timeline various onComplete functions on different tweens
首先,我是GSAP和ScrollMagic的新手,如果我在这里问了一个愚蠢的问题,请原谅我。我一直在网上找,但没能找到我问题的正确答案。
无论如何,我试图创建一个时间线,在每个"to"函数完成时,将使用特定的params调用外部函数。
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中。
我的问题的解决方案是什么,或者什么是一个好的替代方法?
编辑:这是一个JSFiddle:https://jsfiddle.net/04db5ja5/
谢谢,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");
...
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- jQuery中是否内置了任何字符串格式化函数
- GSAP时间轴上的各种onComplete函数在不同的tweens上