Schedule your callback function to be run every second, close to when the system clock changes.
This relies on the setTimeout()
global function.
npm install top-of-second-ticker --save
This package exposes a single class with five methods: start(callback)
, pause()
, resume()
, stop()
, getIsRunning()
.
import TopOfSecondTicker from 'top-of-second-ticker'
const ticker = new TopOfSecondTicker()
// start immediately
ticker.start((scheduledDate) => {
console.log('ran', schdeuledDate)
})
// stop after ten seconds
setTimeout(ticker.stop, 10 * 1000)
// pause when the browser becomes inactive
document.addEventListener('visibilitychange', (_) => {
if (document.visibilityState === 'visible')
ticker.resume()
else
ticker.pause()
})
-
Constructor takes no arguments.
-
.start(callback, shouldExecuteCallbackImmediately = true)
callback
is your function to be executed repeatedly. It will be passed one argument: aDate
object for when this class intended to execute the callback (at the top of the second). Thus, the date's.valueOf()
(in milliseconds) will be divisible by 1000. IfshouldExecuteCallbackImmediately
istrue
(the default, see explanation below), the first timecallback
is executed, its date will beundefined
.Note: The actual exact time that
callback
is executed will be some number of milliseconds after the intended Date. If your code runs smoothly, this delay should be imperceptible to the user. For reference, seesetTimeout()
's Reasons for delays longer than specifiedIf
shouldExecuteCallbackImmediately
isfalse
,callback
will not be executed until the top of the next second.If
.start(...)
is called multiple times on the same ticker instance, the previouscallback
s are forgotten. Only the most recentcallback
will continue to execute repeatedly. -
.pause()
takes no arguments.When paused, the most recent
callback
is still remembered, so you can easily call.resume()
again to continue execution. -
.resume(shouldExecuteCallbackImmediately = true)
shouldExecuteCallbackImmediately
behaves just like the argument to.start(...)
above.This returns
true
if acallback
was still remembered and either just executed (immediately), or will execute at the top of the next second. -
.stop()
takes no arguments.Once stopped, the
callback
is forgotten, andresume()
has no effect (until you call.start(...)
again). -
.getIsRunning()
will return false if stopped or paused.