我正在看看ScrollMagic的文档。我看到我可以使用回调函数来改变滚动行为,如下所示:
controller.scrollTo(function (newScrollPos) {
$("body").animate({scrollTop: newScrollPos});
});
有没有办法将更多参数传递给此函数?对于某些特定链接/锚点,我想使用偏移量。我无法弄清楚如何传递更多参数,或者如何从回调中获取ScrollTarget。
答案 0 :(得分:0)
此函数仅用于接收一个数字,因为它应该做的就是创建一个移动到该数字的自定义滚动行为。
但是,您可以使用this
在回调中引用控制器。
在自定义回调被调用之前,处理将元素或场景位置转换为滚动位置(如果向controller.scrollTo
提供元素或场景)的功能。
因此,要使其与特定情况的某些偏移一起使用,您需要在实际调用函数之前处理它。
例如,在您的点击处理程序中。
这是一些伪代码:
anchor.on(click, function() {
if (this is an exception) {
var customPos = targetElement.offset().top + offset;
controller.scrollTo(customPos);
} else {
controller.scrollTo(targetElement);
}
});