jquery:将动画绑定到滚动条位置的更好方法

jquery: a better way to tie an animation to scrollbar position

本文关键字:位置 更好 方法 滚动条 动画 绑定 jquery      更新时间:2023-09-26
var AddFootnoteScrollIndicator = function(){
    $('.mobileFootnote').on('scroll touchmove', function (event) {
        var scrollTop = that.$mobileFootnote.scrollTop();                
        if (scrollTop <= 20){
            var opacity = 1 - (scrollTop/20);
            $('.scroll-down-indicator').css({'opacity': opacity });
        }
    });
};

当用户向下滚动时,指示器会慢慢淡出,直到消失。它们向上滚动,指示器慢慢重新出现。它们停在中间,指示器半可见。

代码工作正常,但通过.css()修改不透明度似乎很昂贵。有没有更聪明的方法可以通过 css 或......

我不想延迟.on()轮询,因为动画需要快速响应滚动。

有什么想法吗?

当涉及到滚动事件时,通过javascript修改css是唯一的方法。纯 CSS 无法像媒体查询和屏幕尺寸那样检测滚动位置。

jquery css() 函数正在后台设置 element.style.opacity 属性。您只是实际元素属性的一个短抽象层,因此它并不"昂贵"。

该调用中最昂贵的部分是$('.scroll-down-indicator')选择器,因为它必须执行 DOM 遍历才能找到具有类名的元素。