Home

Awesome

jQuery countTo Plugin

jQuery countTo is a jQuery plugin that will count up (or down) to a target number at a specified speed, rendered within an HTML DOM element.

Requirements:

jQuery countTo requires the latest version of jQuery.

Usage:

There are two main approaches to using this plugin: through data attributes on DOM nodes, and through JS options explicitly passed to the countTo function.

These two methods can be mixed and matched as well. Data attributes takes precedence over JS options.

Data Attributes

This approach allows you to define data-* attributes on whatever DOM element will act as a container for your counter. This is useful when you already know the values at the time that you are constructing the DOM.

<span class="timer" data-from="25" data-to="75"></span>

<script type="text/javascript">
  $('.timer').countTo();
</script>

A more detailed example that demonstrates all possible options being used is as follows.

<span class="timer" data-from="0" data-to="100"
      data-speed="5000" data-refresh-interval="50"></span>

<script type="text/javascript">
  $('.timer').countTo();
</script>

Refer to the Options section below for more info on the various options available.

JavaScript Options

This approach allows you to pass values to the countTo function. This is useful when you don't know the values at the time the DOM is being rendered.

<span class="timer"></span>

<script type="text/javascript">
  $('.timer').countTo({from: 0, to: 500});
</script>

A more detailed example that demonstrates all possible options being used is as follows.

<span class="timer"></span>

<script type="text/javascript">
  $('.timer').countTo({
    from: 50,
    to: 2500,
    speed: 1000,
    refreshInterval: 50,
    formatter: function (value, options) {
      return value.toFixed(options.decimals);
    },
    onUpdate: function (value) {
      console.debug(this);
    },
    onComplete: function (value) {
      console.debug(this);
    }
  });
</script>

Refer to the Options section below for more info on the various options available.

Options:

A complete listing of the options that can be passed to the countTo method is below.

<table> <tr> <th>Option</th> <th>Data Attribute</th> <th>Description</th> </tr> <tr> <td><i>from</i></td> <td><i>data-from</i></td> <td>The number to start counting from. <i>(default: 0)</i></td> </tr> <tr> <td><i>to</i></td> <td><i>data-to</i></td> <td>The number to stop counting at. <i>(default: 100)</i></td> </tr> <tr> <td><i>speed</i></td> <td><i>data-speed</i></td> <td>The number of milliseconds it should take to finish counting. <i>(default: 1000)</i></td> </tr> <tr> <td><i>refreshInterval</i></td> <td><i>data-refresh-interval</i></td> <td>The number of milliseconds to wait between refreshing the counter. <i>(default: 100)</i></td> </tr> <tr> <td><i>decimals</i></td> <td><i>data-decimals</i></td> <td>The number of decimal places to show when using the default formatter. <i>(default: 0)</i></td> </tr> <tr> <td colspan="2"><i>formatter (value, options)</i></td> <td>A handler that is used to format the current value before rendering to the DOM. The true current value and options set is passed to the function, and it is run in the context of the DOM element. It must return the formatted value. <i>(default: <code>value.toFixed(options.decimals)</code>)</i></td> </tr> <tr> <td colspan="2"><i>onUpdate (value)</i></td> <td>A callback function that is triggered for every iteration that the counter updates. The currently rendered value is passed to the function, and it is called in the context of the DOM element. <i>(default: null)</i></td> </tr> <tr> <td colspan="2"><i>onComplete (value)</i></td> <td>A callback function that is triggered when counting finishes. The final rendered value is passed to the function, and it is called in the context of the DOM element. <i>(default: null)</i></td> </tr> </table>

Functions:

This plugin also supports functions, primarily for changing state. Functions are called by passing the name as a string to the countTo jQuery function, e.g.: $('#timer').countTo('stop').

<table> <tr> <td><i>start</i></td> <td>Resumes the timer if it is stopped.</td> </tr> <tr> <td><i>stop</i></td> <td>Stops (pauses) the timer if it is running.</td> </tr> <tr> <td><i>toggle</i></td> <td>Starts or stops the timer based upon its current state.</td> </tr> <tr> <td><i>restart</i></td> <td>Restarts the timer at its initial "from" value.</td> </tr> </table>

Created By:

Matt Huggins

License:

jQuery-countTo is released under the MIT license.