У Дэвида Уолша есть отличная реализация защиты от дребезга здесь.
// Returns a function, that, as long as it continues to be invoked, will not
// be triggered. The function will be called after it stops being called for
// N milliseconds. If `immediate` is passed, trigger the function on the
// leading edge, instead of the trailing.
function debounce(func, wait, immediate) {
var timeout;
return function() {
var context = this, args = arguments;
var later = function() {
timeout = null;
if (!immediate) func.apply(context, args);
};
var callNow = immediate && !timeout;
clearTimeout(timeout);
timeout = setTimeout(later, wait);
if (callNow) func.apply(context, args);
};
};
Я использую его в производстве, и он отлично работает.
Теперь я столкнулся с немного более сложным случаем необходимости устранения дребезга.
У меня есть событие, которое вызывает обработчик событий с таким параметром: $(elem).on('onSomeEvent', (e) => {handler(e.X)} );
Я согласен с тем, что это событие часто запускается и вызывает обработчик даже 1000 раз в секунду. Мне не нужно устранять дребезг самого обработчика. Но в моем случае для каждого e.X я хочу, чтобы он вызывался только один раз за период, скажем, 250 мс.
Я думал о создании двумерного массива, который содержит x и время последнего выполнения, но я не хочу объявлять какие-либо глобальные переменные.
Любые идеи?
* ИЗМЕНИТЬ *
Прочитав ответ @Tim Vermaelen, я реализовал это так, и это сработало:
export function debounceWithId(func, wait, id, immediate?) {
var timeouts = {};
return function () {
var context = this, args = arguments;
var later = function () {
timeouts[id] = null;
if (!immediate) func.apply(context, args);
};
var callNow = immediate && !timeouts[id];
clearTimeout(timeouts[id]);
timeouts[id] = setTimeout(later, wait);
if (callNow) func.apply(context, args);
};
};
var timeout
тоже не является глобальной переменной в исходном коде? - person Bergi   schedule 12.12.2016