A lightweight and dependency-free number counter that animates numbers incrementing or decrementing, which allows you to control the 'speed' too!
- Either include the CDN
https://unpkg.com/countanimator@1.2.1/dist/countanimator.js
or install it as an NPM package.
npm i countanimator
- Import the package (you can skip this step if you've included the CDN script).
import CountAnimator from 'countanimator';
- Pass the necessary arguments to the constructor.
The constructor takes two arguments - an HTML element and an optional object (consists of the following keys: start
, end
, steps
, delay
).
-
selector
- selector for the element that should output the number (required) -
start
- number to start counting from (default value is 0) -
end
- number to end counting at (default value is 100) -
steps
- number of steps to increment or decrement by. Only whole numbers are allowed (ie. 0, 1, 2, 3, 4, ...) (default value is 1) -
delay
- number to indicate the delay between increments or decrements. You can think of this as the "speed" of the number counter. Negative numbers cannot be used. Maximum value is 100 (default value is 50)
const options = {
start: 0,
end: 50,
steps: 1,
delay: 70
};
- Instantiate the
CountAnimator
class and pass in the arguments object.
const countAnimator = new CountAnimator(selector, options);
- Initialize the counter when you're ready by invoking
.init()
.
countAnimator.init();
Example of a simple program that counts from 0 to 50 when you click a button:
import CountAnimator from 'countanimator'; // not required if using CDN
const btn = document.querySelector('button');
const options = {
start: 0,
end: 50,
steps: 1,
delay: 70
};
const countAnimator = new CountAnimator('div', options);
btn.addEventListener('click', () => {
countAnimator.init();
});