Javascript 有没有办法让我的元素(图标、字体)在滚动时更改,然后在滚动停止时更改回来?
我有一个一页的设计,我一直在工作,我想改变某些元素,而滚动,但有他们还原时,滚动停止。我已经尝试使用如下所示的scrollTop功能,但这会无限期地更改项目Javascript 有没有办法让我的元素(图标、字体)在滚动时更改,然后在滚动停止时更改回来?,javascript,jquery,scroll,Javascript,Jquery,Scroll,我有一个一页的设计,我一直在工作,我想改变某些元素,而滚动,但有他们还原时,滚动停止。我已经尝试使用如下所示的scrollTop功能,但这会无限期地更改项目 jQuery(窗口)。滚动(函数(){ var fromTopPx=20; var scrolledFromtop=jQuery(window.scrollTop(); 如果(从顶部滚动>从顶部滚动){ jQuery('.homeicon').addClass('fa-angle-double-down'); }否则{ jQuery('.
jQuery(窗口)。滚动(函数(){
var fromTopPx=20;
var scrolledFromtop=jQuery(window.scrollTop();
如果(从顶部滚动>从顶部滚动){
jQuery('.homeicon').addClass('fa-angle-double-down');
}否则{
jQuery('.homeicon').removeClass('fa-angle-double-down');
}
});代码>
.home图标{
填充:100px 5px 1000px 20px;
}
是的,这很容易实现,您需要的是取消图标切换功能,lodash
为此提供了一个功能
结果如下。有关更多信息,请查看debounce文档
注意:使用这种方法更容易,因为这样可以避免进行神奇的计算
const switchBack=()=>{
jQuery('.homeicon').removeClass('fa-angle-double-down');
}
常数去抖动=u.去抖动(切换,250);
jQuery(窗口).滚动(函数(){
//滚动时,我们将类设置为滚动时所需的类(哈哈)
jQuery('.homeicon').addClass('fa-angle-double-down');
//此外,我们还运行了去噪函数。
//我们停止呼叫后,它将运行250毫秒。
脱胶();
});代码>
.home图标{
填充:100px 5px 1000px 20px;
}
非常感谢您!我一直在寻找这样的东西有一段时间了。