Home » , , , , , » FREE Tutorial - Making a jQuery Countdown Timer

FREE Tutorial - Making a jQuery Countdown Timer




When building a coming soon or event page, you find yourself in search for a good way to display the remaining time. A countdown gives the feel of urgency, and combined with an email field will yield more signups for your newsletter.
Today we are going to build a neat jQuery plugin for displaying a countdown timer. It will show the remaining days, hours, minutes and seconds to your event, as well as an animated updates on every second. Note: the plugin is also available on Github.
Let’s start with the markup!

The HTML

We will give the plugin the creative name of “countdown”. Called on an empty element, it will fill it with the HTML that is needed for the countdown timer. You don’t need to do anything but choose the element in which you want to show it.

Generated markup

01<div id="countdown" class="countdownHolder">
02    <span class="countDays">
03        <span class="position">
04            <span class="digit static"></span>
05        </span>
06        <span class="position">
07            <span class="digit static"></span>
08        </span>
09    </span>
10
11    <span class="countDiv countDiv0"></span>
12
13    <span class="countHours">
14        <span class="position">
15            <span class="digit static"></span>
16        </span>
17        <span class="position">
18            <span class="digit static"></span>
19        </span>
20    </span>
21
22    <span class="countDiv countDiv1"></span>
23
24    <span class="countMinutes">
25        <span class="position">
26            <span class="digit static"></span>
27        </span>
28        <span class="position">
29            <span class="digit static"></span>
30        </span>
31    </span>
32
33    <span class="countDiv countDiv2"></span>
34
35    <span class="countSeconds">
36        <span class="position">
37            <span class="digit static"></span>
38        </span>
39        <span class="position">
40            <span class="digit static"></span>
41        </span>
42    </span>
43
44    <span class="countDiv countDiv3"></span>
45</div>
In the above example, the plugin has been originally called on a div with an id of countdown. The plugin has then added a countdownHolder class to it (so a few styles are applied to the element via CSS).
Inside is the markup for the digits. There are two digit spans for every time unit (days, hours, minutes and seconds), which means that you can count down towards a date that is no more than 99 days in the future (for such time frames you should probably not use the timer anyway, it would be discouraging).
The static class of the digits gives them their gradient background and box-shadow. When animated, this class is removed so that these CSS3 touches don’t slow down the animation. The digits are brought together in groups so you can easily style them. Adding a font-size declaration to .countDays, will affect the size of both day digits.
A jQuery Countdown Timer
A jQuery Countdown Timer
The .countDiv spans are the dividers between the units. The colon is formed with :before/:after elements.
But how is this markup generated exactly?

The jQuery

First let’s write two helper functions used by the plugin:
  • init generates the markup you saw above;
  • switchDigit takes a .position span and animates the digits inside it;
Extracting this functionality as separate functions allows us to keep the plugin code clean.

assets/countdown/jquery.countdown.js

01function init(elem, options){
02    elem.addClass('countdownHolder');
03
04    // Creating the markup inside the container
05    $.each(['Days','Hours','Minutes','Seconds'],function(i){
06        $('<span class="count'+this+'">').html(
07            '<span class="position">\
08                <span class="digit static">0</span>\
09            </span>\
10            <span class="position">\
11                <span class="digit static">0</span>\
12            </span>'
13        ).appendTo(elem);
14
15        if(this!="Seconds"){
16            elem.append('<span class="countDiv countDiv'+i+'"></span>');
17        }
18    });
19
20}
21
22// Creates an animated transition between the two numbers
23function switchDigit(position,number){
24
25    var digit = position.find('.digit')
26
27    if(digit.is(':animated')){
28        return false;
29    }
30
31    if(position.data('digit') == number){
32        // We are already showing this number
33        return false;
34    }
35
36    position.data('digit', number);
37
38    var replacement = $('<div>',{
39        'class':'digit',
40        css:{
41            top:'-2.1em',
42            opacity:0
43        },
44        html:number
45    });
46
47    // The .static class is added when the animation
48    // completes. This makes it run smoother.
49
50    digit
51        .before(replacement)
52        .removeClass('static')
53        .animate({top:'2.5em',opacity:0},'fast',function(){
54            digit.remove();
55        })
56
57    replacement
58        .delay(100)
59        .animate({top:0,opacity:1},'fast',function(){
60            replacement.addClass('static');
61        });
62}
Great! Now let’s move on with the plugin body. Our plugin must take an object with parameters for better configurability – a timestamp of the period we are counting towards, and a callback function, executed on every tick and passed the remaining time. For brevity, I’ve omitted the functions above from the code.

assets/countdown/jquery.countdown.js

01(function($){
02
03    // Number of seconds in every time division
04    var days    = 24*60*60,
05        hours   = 60*60,
06        minutes = 60;
07
08    // Creating the plugin
09    $.fn.countdown = function(prop){
10
11        var options = $.extend({
12            callback    : function(){},
13            timestamp   : 0
14        },prop);
15
16        var left, d, h, m, s, positions;
17
18        // Initialize the plugin
19        init(this, options);
20
21        positions = this.find('.position');
22
23        (function tick(){
24
25            // Time left
26            left = Math.floor((options.timestamp - (new Date())) / 1000);
27
28            if(left < 0){
29                left = 0;
30            }
31
32            // Number of days left
33            d = Math.floor(left / days);
34            updateDuo(0, 1, d);
35            left -= d*days;
36
37            // Number of hours left
38            h = Math.floor(left / hours);
39            updateDuo(2, 3, h);
40            left -= h*hours;
41
42            // Number of minutes left
43            m = Math.floor(left / minutes);
44            updateDuo(4, 5, m);
45            left -= m*minutes;
46
47            // Number of seconds left
48            s = left;
49            updateDuo(6, 7, s);
50
51            // Calling an optional user supplied callback
52            options.callback(d, h, m, s);
53
54            // Scheduling another call of this function in 1s
55            setTimeout(tick, 1000);
56        })();
57
58        // This function updates two digit positions at once
59        function updateDuo(minor,major,value){
60            switchDigit(positions.eq(minor),Math.floor(value/10)%10);
61            switchDigit(positions.eq(major),value%10);
62        }
63
64        return this;
65    };
66
67    /* The two helper functions go here */
1})(jQuery);
The tick function calls itself every second. Inside it, we calculate the time difference between the given timestamp and the current date. The updateDuo function then updates the digits comprising the time unit.
The plugin is ready! Here is how to use it (as seen in the demo):

assets/js/script.js

01$(function(){
02
03    var note = $('#note'),
04        ts = new Date(2012, 0, 1),
05        newYear = true;
06
07    if((new Date()) > ts){
08        // The new year is here! Count towards something else.
09        // Notice the *1000 at the end - time must be in milliseconds
10        ts = (new Date()).getTime() + 10*24*60*60*1000;
11        newYear = false;
12    }
13
14    $('#countdown').countdown({
15        timestamp   : ts,
16        callback    : function(days, hours, minutes, seconds){
17
18            var message = "";
19
20            message += days + " day" + ( days==1 ? '':'s' ) + ", ";
21            message += hours + " hour" + ( hours==1 ? '':'s' ) + ", ";
22            message += minutes + " minute" + ( minutes==1 ? '':'s' ) + " and ";
23            message += seconds + " second" + ( seconds==1 ? '':'s' ) + " <br />";
24
25            if(newYear){
26                message += "left until the new year!";
27            }
28            else {
29                message += "left to 10 days from now!";
30            }
31
32            note.html(message);
33        }
34    });
35
36});
Of course, for this to work, you will have to include the css and js file from the countdown folder in your page.

Done!

You can use this script as the perfect addition to every launch page. The best thing about it is that it doesn’t use a single image, everything is done with CSS alone. Increasing or decreasing the font size will result in everything scaling nicely, and you only need a display:none declaration to hide the units you don’t need

Share this article :

0 comments:

Post a Comment

 
Support : Femin Collection | Habitat Design | Kreatifa Media
Copyright © 2013. Kreatifa Media - All Rights Reserved
Template Created by Habitat Design Published by Kreatifa Media
Proudly powered by Blogger