What is shockproof?
The setTimeout method is used to turn multiple fires into one at a certain time interval. (Collodially, it is said that the last click interval after the specified time can be successfully triggered again, otherwise the trigger is not successful)
The realization idea of anti – shaking
- Set a timer variable t to null in the upper scope of the function returned by the stabilization function.
- T is used to determine whether it is the first execution.
- If this is not the first time, clear the timer
- If this is the first execution, then apply(this,arguments) is used.
- Finally, set the timer, and set T to NULL after the specified time, so that t is null after the interval, and the click after the interval becomes the first click.
Stabilization implementation code
const btn = document.querySelector('#input');
btn.addEventListener('click',debounce(submit,3000),false);
function submit(e) {
console.log(1);
}
// Shake stabilization function: all clicks within 3 seconds after the last click are invalid
function debounce(fn,timer) {
let t = null;
return function() {
// Check whether it is the first execution
letfirstClick = ! t;// If it is not executed for the first time, the reason for the delay is to prevent the previous timer from affecting the latest timer.
if (t) { clearTimeout(t)};
// If this is the first execution, execute directly
if (firstClick) {
fn.apply(this.arguments)}// Set t to null after the specified interval after the first click to prepare for the next first click
t = setTimeout(() = > {
t = null;
},timer)
}
}
Copy the code
CodeSandBox online demo
What is throttling?
Throttling refers to reducing the trigger frequency over a period of time. It can only be triggered again after a specified interval of the last successful trigger.
Throttling implementation ideas
- Begin = 0; begin = 0; begin = 0;
- Get the current timestamp, if (current timestamp – initial > specified interval) then apply to change this point and pass the parameter;
- Change the initial value to the current value;
Throttling implementation code
const btn = document.querySelector('#input');
btn.addEventListener('click',throttle(submit,2000),false);
function submit(e) {
console.log(1);
}
// Throttling function: reduces the firing frequency for a period of time, and can only be fired successfully again after a specified period of time between the last successful firing.
function throttle(fn,delay) {
let begin = 0;
return function() {
let cur = new Date().getTime();
if (cur - begin > delay) {
fn.apply(this.arguments); begin = cur; }}}Copy the code
CodeSandBox online demo
What’s the difference between throttling and shakiness?
- Shake only after the last successful click interval after the specified time can be successfully triggered again, if the time interval was clicked within the time interval, need to re-interval to click.
- Throttling is different. Throttling can be triggered again by clicking after the specified time of the last successful trigger, and the intermediate trigger has no effect.