startstopinterval

4.0.25 • Public • Published

startStopInterval

Easily start and stop multiple functions uisng setInterval and clearInterval.

Build Status npm version Issue Count Test Coverage Known Vulnerabilities

Problem

Often one may come across the need of calling a function at specified intervals. This is were the native setInterval function comes to use. However at times it could 'get messy' and gets better if you add multiple functions into the mix .

Solution

It would be nice if one had a function to start and stop a particular function executing at specified intervals. Thus the need for "startStopInterval" to make it simple and easy. This is intended to

  • start and stop a function
  • start and stop multiple functions
  • pass arguments to function(s)
  • provide interval to function(s)

Install

npm install startstopinterval

Usage

//Step 1: Require startstopinterval.
var ssi= require("startstopinterval");
// Step 2: start by passing true in startstopinterval.
// functionToExecute - any function to call start at specified intervals.
// 1000              - interval
ssi.startStopInterval(true,functionToExecute,1000);
// Step 3: stop by passing false and functionToExecute in startstopinterval .
ssi.startStopInterval(false,functionToExecute);

Example

Example 1: Lazy usage in node.
https://github.com/vinayakkankanwadi/usingstartstopinterval
var ssi= require("startstopinterval");
 
// sleep time expects milliseconds
function sleep (time) {
  return new Promise((resolve) => setTimeout(resolve, time));
}
 
function fn() {
  var d = new Date();
  console.log(d);
}
 
console.log("start")
ssi.startStopInterval(true,fn,1000);
 
sleep(5000).then(() => {
 console.log("stop");
 ssi.startStopInterval(false,fn);
});
Example 2: Lazy function usage in html.
https://github.com/vinayakkankanwadi/startStopInterval/blob/master/demo.html
<p id="demo"></p>
 
<button onclick="startStopInterval(true,fn)">Start time</button>
<button onclick="startStopInterval(false,fn)">Stop time</button>
 
 
<script type="text/javascript" src="startstopinterval.js"></script>
<script>
function fn() {
    var d = new Date();
    document.getElementById("demo").innerHTML = "Time:"+ d.toLocaleTimeString();
}
</script>
 
Example 3: Lazy multiple function usage in html.
https://github.com/vinayakkankanwadi/startStopInterval/blob/master/demo.html
<p id="demo"></p>
<p id="demo1"></p>
 
<button onclick="startStopInterval(true,fn,1000)">Start time</button>
<button onclick="startStopInterval(false,fn)">Stop time</button>
 
<button onclick="startStopInterval(true,fn1,1000,[5,'one'])">Start time</button>
<button onclick="startStopInterval(false,fn1)">Stop time</button>
 
<script type="text/javascript" src="startstopinterval.js"></script>
<script>
function fn() {
    var d = new Date();
    document.getElementById("demo").innerHTML = "Time:"+ d.toLocaleTimeString();
}
function fn1(fnArguments) {
    var d = new Date();
    document.getElementById("demo1").innerHTML = fnArguments+"Time:"+ d.toLocaleTimeString();
}
</script>

Tests

npm install
npm test

License

https://github.com/vinayakkankanwadi/startStopInterval/blob/master/LICENSE

Package Sidebar

Install

npm i startstopinterval

Weekly Downloads

1

Version

4.0.25

License

MIT

Last publish

Collaborators

  • vinayakkankanwadi