Small knowledge, big challenge! This article is participating in the creation activity of “Essential Tips for Programmers”.
preface
Yesterday, I posted an article about anti-shake, many people asked why throttling was not written together. This is of course because yesterday that was on the experiment class touch fish to write, throttling did not touch out, hey hey.
But don’t panic, throttle back, it’s coming!
The function of throttling is similar to that of shaking prevention, both to limit the frequent triggering of events.
Anti-shake article link: it’s 2021, can’t still know anti-shake?
How to Throttle
To realize throttling, we must first understand the principle of throttling.
Throttling is executing only one event at a time.
Or, once in a while, only one event is executed.
To make a distinction with anti – shake oh ~
Anti – shake is, no matter how many times you trigger, I only look at the last time you trigger, and execute the event after a certain amount of time.
I learned that there are two ways of throttling, namely timestamp and timer.
So let’s implement it
The time stamp
Use timestamp, when the triggering event, we record the current timestamp, then minus the before record timestamp (don’t forget to set the start value must be 0), if is greater than the set period of time (i.e., the interval of time), executive function, and then update timestamp for the current timestamp, if less than, can not perform.
Is it easy? So let’s write that down.
The specific example is still using the anti – shake function, I don’t want to write another one, heh heh ~ replace the anti – shake function with throttling
Anti-shake article link: it’s 2021, can’t still know anti-shake?
function throttle(todo, time) {
var pre = 0;
return function() {
var now = +new Date(a);var that = this;
if(now - pre > time) { todo.apply(that); pre = now; }}}Copy the code
The words used are the same as before:
btn.onclick = throttle(shake,3000);
Copy the code
Why set 3000, of course, to make the effect look obvious, here is the effect:
All right, all right, stop counting 123 in your head. Let’s keep going.
The timer
When the event is triggered, we set a timer, and when the event is triggered, if the timer exists, it is not executed until the timer is executed, and then the function is executed to clear the timer so that the next timer can be set.
The code:
function throttle(todo, time) {
var timeout,that;
return function() {
that = this;
if(! timeout) { timeout =setTimeout(function(){
timeout = null;
todo.apply(that)
}, time)
}
}
}
Copy the code
Look at the results:
As can be seen, it took 3s for it to take effect, but I don’t know why, this way does not give me a very good experience, maybe because it is not the next moment to click the feedback ~
Wouldn’t it be better to add a transition animation to this one?
To compare
Since there are two ways, let’s talk about the differences.
The first type: it can be clearly seen in the example that there is feedback immediately after the trigger is clicked (the first execution), and the next execution will not be carried out until the waiting time expires. If the trigger is stopped, the next execution will not be carried out.
The second way: the first time is executed after the wait time, and the second time is executed when the trigger is stopped.
Saw such adjectives on the net: have no tail and have no head have tail, is not very image.
The last
Ah, the end at last! Or that sentence, maybe I think of or write is not very perfect, I hope you can point out, I will correct in time.
If I think there is a place to optimize, I will come back to update!
Give it a thumbs up, let’s learn and progress together!