Fleegix.js
Simple. Useful. JavaScript.

Plugins: fleegix.date.util


Some useful methods for dealing with dates, including:

Download fleegix.date.util (19KB)

fleegix.date.util.strftime

Syntax

fleegix.date.util.strftime(dt, formatString);

Parameters

dt (Object/Date or Number) -- The date to be formatted, JS Date or numeric timestamp.

formatString (String) -- Indicates how the date is to be formatted.

Description

Formats a date or time according to a given format string -- identical to the strftime function found in many scripting languages such as Perl, Ruby, or PHP.

Formattting

The format string may include the following specifiers:

%a--Abbreviated weekday name (ex. Thu)
%A--Full weekday name (ex. Thursday)
%b--Abbreviated month name (ex. Nov)
%B--Full month name (ex. November)
%c--Appropriate date and time representation (ex. Thu Nov 03 13:10:35 2005)
%C--Century number (the year divided by 100 and truncated to an integer, range 00 to 99), single digits are preceded by zero (ex. 20)
%d--Day of month (range 01 to 31), single digits are preceded by zero (ex. 03)
%D--Date as %m/%d/%y (ex. 11/03/05)
%e--Day of the month as a decimal number (range ' 1' to '31') -- a single digit is preceded by a space (ex. ' 3')
%F--Same as %Y-%m-%d
%h--Same as %b (ex. Nov)
%H--Hour as a decimal number using a 24-hour clock (range 00 to 23), single digits are preceded by zero (ex. 13)
%I--Hour as a decimal number using a 12-hour clock (range 01 to 12), single digits are preceded by zero (ex. 01)
%j--Day of the year as a decimal number (range 001 to 366) -- zero-padded to three digits (ex. 307)
%k--Hour as a decimal number using a 24-hour clock (range ' 0' to '23'), single digits are preceded by a space (ex. '13')
%l--Hour as a decimal number using a 12-hour clock (range ' 1' to '12'), single digits are preceded by a space (ex. ' 1')
%m--Month as a decimal number (range 01 to 12), single digits are preceded by zero (ex. 11)
%M--Minute as a decimal number (range 00 to 59), single digits are preceded by zero (ex. 10)
%n--Linefeed character ('\n')
%p--Either 'AM' or 'PM' according to the given time value (ex. PM)
%r--Appropriate time representation in 12-hour clock format with %p (ex. 01:10:35 PM)
%R--Time as %H:%M (ex. 13:10)
%S--Second as a decimal number (range 00 to 59), single digits are preceded by zero (ex. 35)
%t--Tab character ('\t')
%T--Time as %H:%M:%S (ex. 13:10:35)
%u--Weekday as a decimal number (range 1 to 7), with 1 representing Monday (ex. 4)
%w--Weekday as a decimal number (range 0 to 6), with 0 representing Sunday (ex. 4)
%x--Appropriate date representation without the time (ex. 11/03/05)
%X--Appropriate time representation without the date (ex. 01:10:35)
%y--Year as a decimal number without a century (range 00 to 99), single digits are preceded by zero (ex. 05)
%Y--Year as a decimal number including the century (ex. 2005)
%%--A literal percent character (ex. %)

Examples

var bd = new Date('12/27/1968');
fleegix.date.util.strftime(bd, 'My birthdate was %A, %B %e, %Y.');
=> 'My birthdate was Friday, December 27, 1968.'

var dt = new Date('10/01/2112');
fleegix.date.util.strftime(dt, 'I found a guitar in %B of %Y.');
=> 'I found a guitar in October of 2112.'

fleegix.date.util.add

Syntax

someHash.add(someKey, value);

Parameters

dt (Object/Date or Number) -- The date to be incremented/decremented.

interval (constant, see fleegix.date.util.dateParts) -- the unit (e.g., days, weeks, hours, minutes) of time that the date is to be incremented/decremented.

count (Number) -- The number of the desired units to increment/decrement the date.

Description

Increments/decrements a date by some number of a specified unit of time (e.g., adds three weeks, subtracts eight hours).

Examples

var dateParts = fleegix.date.util.dateParts;
// Add 10 years
var bd = new Date('12/27/1968');
bd = fleegix.date.util.add(bd, dateParts.YEAR, 10);
=> Wed Dec 27 1978 00:00:00 GMT-0600 (CST)

// Subtract 2 hours
var dt = new Date(2112, 9, 1, 12, 45);
dt = fleegix.date.util.add(dt, dateParts.HOUR, -2);
=> Sat Oct 01 2112 10:45:00 GMT-0500 (CDT)

fleegix.date.util.diff

Syntax

fleegix.date.util.diff(dtA, dtB, interval);

Parameters

dtA, dbB (Object/Date or Number) -- The dates to be compared.

interval (constant, see fleegix.date.util.dateParts) -- the unit (e.g., days, weeks, hours, minutes) of time to use when comparing the two dates.

Description

Returns the time difference between two dates, measured in a specified unit of time (e.g., how many days between, how many hours between, how many weeks between).

Examples

var dateParts = fleegix.date.util.dateParts;

// Number of months between these dates
var dt1 = new Date('01/01/2112');
var dt2 = new Date('10/01/2112');
var diff = fleegix.date.util.diff(dt1, dt2, dateParts.MONTH);
=> 9

// Number of weekdays between these dates
var dt1 = new Date('09/11/2007');
var dt2 = new Date('09/28/2007');
var diff = fleegix.date.util.diff(dt1, dt2, dateParts.WEEKDAY);
=> 13