Funkce JavaScript Debounce

Jednou z největších chyb, kterou vidím při optimalizaci stávajícího kódu, je absence funkce debounce. Pokud vaše webová aplikace používá JavaScript k provádění daňových úkolů, je funkce debounce nezbytná k zajištění toho, aby se daná úloha nespouštěla ​​tak často, že by to brzdilo výkon prohlížeče.

Pro ty z vás, kteří nevědí, co funkce debounce dělá, omezuje rychlost, jakou může funkce spouštět. Rychlý příklad: v okně máte posluchače změny velikosti, který provádí některé výpočty rozměrů prvků a (možná) přemístí několik prvků. To není samo o sobě těžký úkol, ale opakované spouštění po mnoha změnách velikosti skutečně zpomalí váš web. Proč neomezit rychlost, kterou může funkce spouštět?

Zde je základní funkce debounce JavaScriptu (převzatá z Underscore.js):

// 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);
	};
};

Předáte funkci debounce funkci, která se má provést, a limitu rychlosti střelby v milisekundách. Zde je příklad použití:

var myEfficientFn = debounce(function() {
	// All the taxing stuff you do
}, 250);

window.addEventListener('resize', myEfficientFn);

Výše uvedená funkce se spustí pouze jednou za čtvrt sekundy, nikoli tak rychle, jak byla spuštěna; v některých případech neuvěřitelné zvýšení výkonu.

Často se mě ptají, jaká rychlost by měla být použita při odrazu, a je nemožné na to odpovědět, protože to závisí na úkolu. Nejlepší způsob, jak to zjistit, je sami otestovat různé rychlosti a zjistit, kde si všimnete zpomalení – pokud si toho všimnete, všimnou si ho i vaši uživatelé!