Javascript jQuery - 滚动停止时绑定事件
声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow
原文地址: http://stackoverflow.com/questions/14035083/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me):
StackOverFlow
jQuery - bind event on Scroll Stop
提问by itsme
If i want to bind an event on page scrolling i can use scroll();.
如果我想在页面滚动时绑定一个事件,我可以使用scroll();.
But how to fire when scroll()is ended up?
但是如何在scroll()结束时触发?
I would like to reproduce this:
我想重现这个:
$(window).scroll(function(){
//do somenthing
});
$(window).scrollSTOPPED(function(){ //--> when i'm scrolling then i stop to scrolling (so NOT when page scrollbar is at the end top or bottom :)
//do somenthing else
});
any ideas?
有任何想法吗?
回答by Jason Sebring
tiny jquery way
微小的jQuery方式
$.fn.scrollStopped = function(callback) {
var that = this, $this = $(that);
$this.scroll(function(ev) {
clearTimeout($this.data('scrollTimeout'));
$this.data('scrollTimeout', setTimeout(callback.bind(that), 250, ev));
});
};
After 250 ms from the last scroll event, this will invoke the "scrollStopped" callback.
在距离上次滚动事件 250 毫秒后,这将调用“scrollStopped”回调。
http://jsfiddle.net/wtRrV/256/
http://jsfiddle.net/wtRrV/256/
lodash (even smaller)
lodash(甚至更小)
function onScrollStopped(domElement, callback) {
domElement.addEventListener('scroll', _.debounce(callback, 250));
}
pure js (technically the smallest)
纯 js(技术上最小的)
function onScrollStopped(domElement, callback, timeout = 250) {
domElement.addEventListener('scroll', () => {
clearTimeout(callback.timeout);
callback.timeout = setTimeout(callback, timeout);
});
}
https://jsfiddle.net/kpsxdcv8/15/
https://jsfiddle.net/kpsxdcv8/15/
strange fact
奇怪的事实
clearTimeout and clearInterval params don't have to be defined and can even be wrong types or even omitted.
clearTimeout 和 clearInterval 参数不必定义,甚至可以是错误类型甚至省略。
回答by OACDesigns
the event itself doesn't exist as scroll is a single event fired everytime the user scrolls by a certain increment.
事件本身不存在,因为滚动是每次用户滚动特定增量时触发的单个事件。
What you can do however is emulate the event.
但是,您可以做的是模拟事件。
Credit to James Padolsey for this, lifted from his webpage:. Read it here to fully understand the code and how it is implemented.
这要归功于 James Padolsey,摘自他的网页:。在此处阅读以完全理解代码及其实现方式。
http://james.padolsey.com/javascript/special-scroll-events-for-jquery/
http://james.padolsey.com/javascript/special-scroll-events-for-jquery/
(function(){
var special = jQuery.event.special, uid1 = 'D' + (+new Date()), uid2 = 'D' + (+new Date() + 1); special.scrollstart = { setup: function() { var timer, handler = function(evt) { var _self = this, _args = arguments; if (timer) { clearTimeout(timer); } else { evt.type = 'scrollstart'; jQuery.event.handle.apply(_self, _args); } timer = setTimeout( function(){ timer = null; }, special.scrollstop.latency); }; jQuery(this).bind('scroll', handler).data(uid1, handler); }, teardown: function(){ jQuery(this).unbind( 'scroll', jQuery(this).data(uid1) ); } }; special.scrollstop = { latency: 300, setup: function() { var timer, handler = function(evt) { var _self = this, _args = arguments; if (timer) { clearTimeout(timer); } timer = setTimeout( function(){ timer = null; evt.type = 'scrollstop'; jQuery.event.handle.apply(_self, _args); }, special.scrollstop.latency); }; jQuery(this).bind('scroll', handler).data(uid2, handler); }, teardown: function() { jQuery(this).unbind( 'scroll', jQuery(this).data(uid2) ); } }; })();
(功能(){
var special = jQuery.event.special, uid1 = 'D' + (+new Date()), uid2 = 'D' + (+new Date() + 1); special.scrollstart = { setup: function() { var timer, handler = function(evt) { var _self = this, _args = arguments; if (timer) { clearTimeout(timer); } else { evt.type = 'scrollstart'; jQuery.event.handle.apply(_self, _args); } timer = setTimeout( function(){ timer = null; }, special.scrollstop.latency); }; jQuery(this).bind('scroll', handler).data(uid1, handler); }, teardown: function(){ jQuery(this).unbind( 'scroll', jQuery(this).data(uid1) ); } }; special.scrollstop = { latency: 300, setup: function() { var timer, handler = function(evt) { var _self = this, _args = arguments; if (timer) { clearTimeout(timer); } timer = setTimeout( function(){ timer = null; evt.type = 'scrollstop'; jQuery.event.handle.apply(_self, _args); }, special.scrollstop.latency); }; jQuery(this).bind('scroll', handler).data(uid2, handler); }, teardown: function() { jQuery(this).unbind( 'scroll', jQuery(this).data(uid2) ); } }; })();
Probably worth noting that there are several questions related to yours, so this may be a possible duplication. e.g. Javascript: do an action after user is done scrollingand Fire event after scrollling scrollbars or mousewheel with javascript
可能值得注意的是,有几个问题与您的问题有关,因此这可能是重复的。例如 Javascript:在用户完成滚动后执行操作,并在使用 javascript 滚动滚动条或鼠标滚轮后触发事件
回答by Cidiomar
You can verify if window.scrollY == 0
您可以验证是否 window.scrollY == 0
$(window).scroll(function(){
if (window.scrollY == 0) {
//...
}
});
But this event will be fired at every scroll.
但是这个事件会在每次滚动时触发。
回答by Frederic Nault
I prefer to be able to listen on a event. This is what I do:
我更喜欢能够收听事件。这就是我所做的:
The jquery plugin:
jquery插件:
+function(jQuery){
var scrollStopEventEmitter = function(element, jQuery) {
this.scrollTimeOut = false;
this.element = element;
jQuery(element).on('scroll', $.proxy(this.onScroll, this));
}
scrollStopEventEmitter.prototype.onScroll = function()
{
if (this.scrollTimeOut != false) {
clearTimeout(this.scrollTimeOut);
}
var context = this;
this.scrollTimeOut = setTimeout(function(){ context.onScrollStop()}, 250);
}
scrollStopEventEmitter.prototype.onScrollStop = function()
{
this.element.trigger('scrollStop');
}
jQuery.fn.scrollStopEventEmitter = function(jQuery) {
return new scrollStopEventEmitter(this, jQuery);
};
}($);
In this case, window will now trigger scrollStop event
在这种情况下,窗口现在将触发 scrollStop 事件
$(window).scrollStopEventEmitter($);
Now I can listen on scrollStop
现在我可以在 scrollStop 上收听
$(window).on('scrollStop',function(){
// code

