1、创建一个只能调用一次的函数。
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());
2、测量 JavaScript 函数运行所需的时间。
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'));
3、一个 debounce 函数,它将调用延迟到自上次调用 debounce 函数以来经过了一定的时间。
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));