Useful JavaScript Functions
The code snippets are from a JavaScript course on Udemy.
- Create a function that can be invoked only once.
const once = (fn, ...args) => {
let called = false;
return () => {
if (called === false) {
called = true;
return fn(...args);
}
return 'Cannot call again';
};
};
const printName = (text, time) => console.log(`${text} at ${time}`);
const fn = once(printName, 'Google', new Date().toString());
console.log(fn());
console.log(fn());
- Measure the time it takes for a JavaScript function to run.
const getUserData = async (user) => {
const response = await fetch(`https://api.github.com/users/${user}`);
const json = await response.json();
return json;
};
const time = (fn, ...args) => {
console.time('time');
const result = fn(...args);
console.timeEnd('time');
return result;
};
time(() => getUserData('labnol'));
- A debounce function that delays invocation until a certain amount of time has passed since the last time that debounce function was invoked.
const debounce = (fn, waitInMs) => {
let debounced = false;
return (...args) => {
if (debounced) clearTimeout(debounced);
debounced = setTimeout(() => fn(...args), waitInMs);
};
};
const getWindowLayout = (event) => {
console.log(event, window.innerHeight, window.innerWidth);
};
window.addEventListener('resize', debounce(getWindowLayout, 500));
Amit Agarwal
Google Developer Expert, Google Cloud Champion
Amit Agarwal is a Google Developer Expert in Google Workspace and Google Apps Script. He holds an engineering degree in Computer Science (I.I.T.) and is the first professional blogger in India.
Amit has developed several popular Google add-ons including Mail Merge for Gmail and Document Studio. Read more on Lifehacker and YourStory