Datepicker Widgetversion added: 1.0
Description: Select a date from a popup or inline calendar
The jQuery UI Datepicker is a highly configurable plugin that adds datepicker functionality to your pages. You can customize the date format and language, restrict the selectable date ranges and add in buttons and other navigation options easily.
By default, the datepicker calendar opens in a small overlay when the associated text field gains focus. For an inline calendar, simply attach the datepicker to a div or span.
Keyboard interaction
While the datepicker is open, the following key commands are available:
-
PAGE UP
: Move to the previous month. -
PAGE DOWN
: Move to the next month. -
CTRL
+PAGE UP
: Move to the previous year. -
CTRL
+PAGE DOWN
: Move to the next year. -
CTRL
+HOME
: Open the datepicker if closed. -
CTRL
/COMMAND
+HOME
: Move to the current month. -
CTRL
/COMMAND
+LEFT
: Move to the previous day. -
CTRL
/COMMAND
+RIGHT
: Move to the next day. -
CTRL
/COMMAND
+UP
: Move to the previous week. -
CTRL
/COMMAND
+DOWN
: Move to the next week. -
ENTER
: Select the focused date. -
CTRL
/COMMAND
+END
: Close the datepicker and erase the date. -
ESCAPE
: Close the datepicker without selection.
Utility functions
$.datepicker.setDefaults( options )
Change the default options for all date pickers.
Use the option()
method to change options for individual instances.
Set all date pickers to open on focus or a click on an icon.
1
2
3
4
5
6
|
|
Set all date pickers to have French text.
1
|
|
$.datepicker.formatDate( format, date, options )
Format a date into a string value with a specified format.
The format can be combinations of the following:
- d - day of month (no leading zero)
- dd - day of month (two digit)
- o - day of the year (no leading zeros)
- oo - day of the year (three digit)
- D - day name short
- DD - day name long
- m - month of year (no leading zero)
- mm - month of year (two digit)
- M - month name short
- MM - month name long
- y - year (two digit)
- yy - year (four digit)
- @ - Unix timestamp (ms since 01/01/1970)
- ! - Windows ticks (100ns since 01/01/0001)
- '...' - literal text
- '' - single quote
- anything else - literal text
There are also a number of predefined standard date formats available from $.datepicker
:
- ATOM - 'yy-mm-dd' (Same as RFC 3339/ISO 8601)
- COOKIE - 'D, dd M yy'
- ISO_8601 - 'yy-mm-dd'
- RFC_822 - 'D, d M y' (See RFC 822)
- RFC_850 - 'DD, dd-M-y' (See RFC 850)
- RFC_1036 - 'D, d M y' (See RFC 1036)
- RFC_1123 - 'D, d M yy' (See RFC 1123)
- RFC_2822 - 'D, d M yy' (See RFC 2822)
- RSS - 'D, d M y' (Same as RFC 822)
- TICKS - '!'
- TIMESTAMP - '@'
- W3C - 'yy-mm-dd' (Same as ISO 8601)
Display the date in ISO format. Produces "2007-01-26".
1
|
|
Display the date in expanded French format. Produces "Samedi, Juillet 14, 2007".
1
2
3
4
5
6
|
|
$.datepicker.parseDate( format, value, options )
Extract a date from a string value with a specified format.
The format can be combinations of the following:
- d - day of month (no leading zero)
- dd - day of month (two digit)
- o - day of year (no leading zeros)
- oo - day of year (three digit)
- D - day name short
- DD - day name long
- m - month of year (no leading zero)
- mm - month of year (two digit)
- M - month name short
- MM - month name long
- y - year (two digit)
- yy - year (four digit)
- @ - Unix timestamp (ms since 01/01/1970)
- ! - Windows ticks (100ns since 01/01/0001)
- '...' - literal text
- '' - single quote
- anything else - literal text
A number of exceptions may be thrown:
- 'Invalid arguments' if either format or value is null
- 'Missing number at position nn' if format indicated a numeric value that is not then found
- 'Unknown name at position nn' if format indicated day or month name that is not then found
- 'Unexpected literal at position nn' if format indicated a literal value that is not then found
- 'Invalid date' if the date is invalid, such as '31/02/2007'
Extract a date in ISO format.
1
|
|
Extract a date in expanded French format.
1
2
3
4
5
6
7
|
|
$.datepicker.iso8601Week( date )
Determine the week of the year for a given date: 1 to 53.
This function uses the ISO 8601 definition of a week: weeks start on a Monday and the first week of the year contains January 4. This means that up to three days from the previous year may be included in the of first week of the current year, and that up to three days from the current year may be included in the last week of the previous year.
This function is the default implementation for the calculateWeek
option.
Find the week of the year for a date.
1
|
|
$.datepicker.noWeekends
Set as beforeShowDay function to prevent selection of weekends.
We can provide the noWeekends()
function into the beforeShowDay
option which will calculate all the weekdays and provide an array of true
/false
values indicating whether a date is selectable.
Set the DatePicker so no weekend is selectable
1
2
3
|
|
Localization
Datepicker provides support for localizing its content to cater for different languages and date formats. Each localization is contained within its own file with the language code appended to the name, e.g., jquery.ui.datepicker-fr.js
for French. The desired localization file should be included after the main datepicker code. Each localization file adds its options to the set of available localizations and automatically applies them as defaults for all instances. Localization files can be found at https://github.com/jquery/jquery-ui/tree/master/ui/i18n.
The $.datepicker.regional
attribute holds an array of localizations, indexed by language code, with ""
referring to the default (English). Each entry is an object with the following attributes: closeText
, prevText
, nextText
, currentText
, monthNames
, monthNamesShort
, dayNames
, dayNamesShort
, dayNamesMin
, weekHeader
, dateFormat
, firstDay
, isRTL
, showMonthAfterYear
, and yearSuffix
.
You can restore the default localizations with:
$.datepicker.setDefaults( $.datepicker.regional[ "" ] );
And can then override an individual datepicker for a specific locale:
$( selector ).datepicker( $.datepicker.regional[ "fr" ] );
Theming
The datepicker widget uses the jQuery UI CSS framework to style its look and feel. If datepicker specific styling is needed, the following CSS class names can be used:
-
ui-datepicker
: The outer container of the datepicker. If the datepicker is inline, this element will additionally have aui-datepicker-inline
class. If theisRTL
option is set, this element will additionally have a class ofui-datepicker-rtl
.-
ui-datepicker-header
: The container for the datepicker's header.-
ui-datepicker-prev
: The control used to select previous months. -
ui-datepicker-next
: The control used to select subsequent months. -
ui-datepicker-title
: The container for the datepicker's title containing the month and year.-
ui-datepicker-month
: The textual display of the month or a<select>
element if thechangeMonth
option is set. -
ui-datepicker-year
: The textual display of the year or a<select>
element if thechangeYear
option is set.
-
-
-
ui-datepicker-calendar
: The table that contains the calendar itself.-
ui-datepicker-week-end
: Cells containing weekend days. -
ui-datepicker-other-month
: Cells containing days that occur in a month other than the currently selected month. -
ui-datepicker-unselectable
: Cells containing days that are not selectable by the user. -
ui-datepicker-current-day
: The cell containing the selected day. -
ui-datepicker-today
: The cell containing today's date.
-
-
ui-datepicker-buttonpane
: The buttonpane that is used when theshowButtonPanel
option is set.-
ui-datepicker-current
: The button used to select today's date.
-
-
If the numberOfMonths
option is used to display multiple months at once, a number of additional classes are used:
-
ui-datepicker-multi
: The outermost container of a multiple month datepicker. This element can additionally have aui-datepicker-multi-2
,ui-datepicker-multi-3
, orui-datepicker-multi-4
class name depending on the number of months to display.-
ui-datepicker-group
: Individual pickers within the group. This element will additionally have aui-datepicker-group-first
,ui-datepicker-group-middle
, orui-datepicker-group-last
class name depending on its position within the group.
-
Dependencies
- UI Core
-
Effects Core (optional; for use with the
showAnim
option)
Additional Notes:
- This widget requires some functional CSS, otherwise it won't work. If you build a custom theme, use the widget's specific CSS file as a starting point.
-
This widget manipulates its element's value programmatically, therefore a native
change
event may not be fired when the element's value changes. -
Creating a datepicker on an
<input type="date">
is not supported due to a UI conflict with the native picker.
Options
altField
""
altFormat
option to change the format of the date within this field. Leave as blank for no alternate field.Initialize the datepicker with the altField
option specified:
1
2
3
|
|
Get or set the altField
option, after initialization:
1
2
3
4
5
|
|
altFormat
""
dateFormat
to be used for the altField
option. This allows one date format to be shown to the user for selection purposes, while a different format is actually sent behind the scenes. For a full list of the possible formats see the formatDate
functionInitialize the datepicker with the altFormat
option specified:
1
2
3
|
|
Get or set the altFormat
option, after initialization:
1
2
3
4
5
|
|
appendText
""
Initialize the datepicker with the appendText
option specified:
1
2
3
|
|
Get or set the appendText
option, after initialization:
1
2
3
4
5
|
|
autoSize
false
true
to automatically resize the input field to accommodate dates in the current dateFormat
.Initialize the datepicker with the autoSize
option specified:
1
2
3
|
|
Get or set the autoSize
option, after initialization:
1
2
3
4
5
|
|
beforeShow
null
beforeShowDay
null
-
[0]
:true
/false
indicating whether or not this date is selectable -
[1]
: a CSS class name to add to the date's cell or""
for the default presentation -
[2]
: an optional popup tooltip for this date
calculateWeek
jQuery.datepicker.iso8601Week
Initialize the datepicker with the calculateWeek
option specified:
1
2
3
|
|
Get or set the calculateWeek
option, after initialization:
1
2
3
4
5
|
|
changeMonth
false
Initialize the datepicker with the changeMonth
option specified:
1
2
3
|
|
Get or set the changeMonth
option, after initialization:
1
2
3
4
5
|
|
changeYear
false
yearRange
option to control which years are made available for selection.Initialize the datepicker with the changeYear
option specified:
1
2
3
|
|
Get or set the changeYear
option, after initialization:
1
2
3
4
5
|
|
closeText
"Done"
showButtonPanel
option to display this button.Initialize the datepicker with the closeText
option specified:
1
2
3
|
|
Get or set the closeText
option, after initialization:
1
2
3
4
5
|
|
constrainInput
true
true
, entry in the input field is constrained to those characters allowed by the current dateFormat
option.Initialize the datepicker with the constrainInput
option specified:
1
2
3
|
|
Get or set the constrainInput
option, after initialization:
1
2
3
4
5
|
|
currentText
"Today"
showButtonPanel
option to display this button.Initialize the datepicker with the currentText
option specified:
1
2
3
|
|
Get or set the currentText
option, after initialization:
1
2
3
4
5
|
|
dateFormat
"mm/dd/yy"
formatDate
function.Initialize the datepicker with the dateFormat
option specified:
1
2
3
|
|
Get or set the dateFormat
option, after initialization:
1
2
3
4
5
|
|
dayNames
[ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" ]
dateFormat
option.Initialize the datepicker with the dayNames
option specified:
1
2
3
|
|
Get or set the dayNames
option, after initialization:
1
2
3
4
5
|
|
dayNamesMin
[ "Su", "Mo", "Tu", "We", "Th", "Fr", "Sa" ]
Initialize the datepicker with the dayNamesMin
option specified:
1
2
3
|
|
Get or set the dayNamesMin
option, after initialization:
1
2
3
4
5
|
|
dayNamesShort
[ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" ]
dateFormat
option.Initialize the datepicker with the dayNamesShort
option specified:
1
2
3
|
|
Get or set the dayNamesShort
option, after initialization:
1
2
3
4
5
|
|
defaultDate
null
dateFormat
, or a number of days from today (e.g. +7) or a string of values and periods ('y' for years, 'm' for months, 'w' for weeks, 'd' for days, e.g. '+1m +7d'), or null for today.- Date: A date object containing the default date.
-
Number: A number of days from today. For example
2
represents two days from today and-1
represents yesterday. -
String: A string in the format defined by the
dateFormat
option, or a relative date. Relative dates must contain value and period pairs; valid periods are"y"
for years,"m"
for months,"w"
for weeks, and"d"
for days. For example,"+1m +7d"
represents one month and seven days from today.
Initialize the datepicker with the defaultDate
option specified:
1
2
3
|
|
Get or set the defaultDate
option, after initialization:
1
2
3
4
5
|
|
duration
"normal"
Initialize the datepicker with the duration
option specified:
1
2
3
|
|
Get or set the duration
option, after initialization:
1
2
3
4
5
|
|
firstDay
0
0
, Monday is 1
, etc.Initialize the datepicker with the firstDay
option specified:
1
2
3
|
|
Get or set the firstDay
option, after initialization:
1
2
3
4
5
|
|
gotoCurrent
false
true
, the current day link moves to the currently selected date instead of today.Initialize the datepicker with the gotoCurrent
option specified:
1
2
3
|
|
Get or set the gotoCurrent
option, after initialization:
1
2
3
4
5
|
|
hideIfNoPrevNext
false
minDate
and maxDate
options). You can hide them altogether by setting this attribute to true
.Initialize the datepicker with the hideIfNoPrevNext
option specified:
1
2
3
|
|
Get or set the hideIfNoPrevNext
option, after initialization:
1
2
3
4
5
|
|
isRTL
false
Initialize the datepicker with the isRTL
option specified:
1
2
3
|
|
Get or set the isRTL
option, after initialization:
1
2
3
4
5
|
|
maxDate
null
null
, there is no maximum.- Date: A date object containing the maximum date.
-
Number: A number of days from today. For example
2
represents two days from today and-1
represents yesterday. -
String: A string in the format defined by the
dateFormat
option, or a relative date. Relative dates must contain value and period pairs; valid periods are"y"
for years,"m"
for months,"w"
for weeks, and"d"
for days. For example,"+1m +7d"
represents one month and seven days from today.
Initialize the datepicker with the maxDate
option specified:
1
2
3
|
|
Get or set the maxDate
option, after initialization:
1
2
3
4
5
|
|
minDate
null
null
, there is no minimum.- Date: A date object containing the minimum date.
-
Number: A number of days from today. For example
2
represents two days from today and-1
represents yesterday. -
String: A string in the format defined by the
dateFormat
option, or a relative date. Relative dates must contain value and period pairs; valid periods are"y"
for years,"m"
for months,"w"
for weeks, and"d"
for days. For example,"+1m +7d"
represents one month and seven days from today.
Initialize the datepicker with the minDate
option specified:
1
2
3
|
|
Get or set the minDate
option, after initialization:
1
2
3
4
5
|
|
monthNames
[ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ]
dateFormat
option.Initialize the datepicker with the monthNames
option specified:
1
2
3
|
|
Get or set the monthNames
option, after initialization:
1
2
3
4
5
|
|
monthNamesShort
[ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" ]
dateFormat
option.Initialize the datepicker with the monthNamesShort
option specified:
1
2
3
|
|
Get or set the monthNamesShort
option, after initialization:
1
2
3
4
5
|
|
nextText
"Next"
Initialize the datepicker with the nextText
option specified:
1
2
3
|
|
Get or set the nextText
option, after initialization:
1
2
3
4
5
|
|
numberOfMonths
1
- Number: The number of months to display in a single row.
- Array: An array defining the number of rows and columns to display.
Initialize the datepicker with the numberOfMonths
option specified:
1
2
3
|
|
Get or set the numberOfMonths
option, after initialization:
1
2
3
4
5
|
|
onChangeMonthYear
null
this
refers to the associated input field.onClose
null
""
if none) and the datepicker instance as parameters. this
refers to the associated input field.onSelect
null
this
refers to the associated input field.prevText
"Prev"
Initialize the datepicker with the prevText
option specified:
1
2
3
|
|
Get or set the prevText
option, after initialization:
1
2
3
4
5
|
|
selectOtherMonths
false
showOtherMonths
option is set to true
.Initialize the datepicker with the selectOtherMonths
option specified:
1
2
3
|
|
Get or set the selectOtherMonths
option, after initialization:
1
2
3
4
5
|
|
shortYearCutoff
"+10"
dateFormat
'y'). Any dates entered with a year value less than or equal to the cutoff year are considered to be in the current century, while those greater than it are deemed to be in the previous century.-
Number: A value between
0
and99
indicating the cutoff year. -
String: A relative number of years from the current year, e.g.,
"+3"
or"-5"
.
Initialize the datepicker with the shortYearCutoff
option specified:
1
2
3
|
|
Get or set the shortYearCutoff
option, after initialization:
1
2
3
4
5
|
|
showAnim
"show"
"show"
(the default), "slideDown"
, "fadeIn"
, any of the jQuery UI effects. Set to an empty string to disable animation.Initialize the datepicker with the showAnim
option specified:
1
2
3
|
|
Get or set the showAnim
option, after initialization:
1
2
3
4
5
|
|
showButtonPanel
false
currentText
and closeText
options respectively.Initialize the datepicker with the showButtonPanel
option specified:
1
2
3
|
|
Get or set the showButtonPanel
option, after initialization:
1
2
3
4
5
|
|
showCurrentAtPos
0
numberOfMonths
option, the showCurrentAtPos
option defines which position to display the current month in.Initialize the datepicker with the showCurrentAtPos
option specified:
1
2
3
|
|
Get or set the showCurrentAtPos
option, after initialization:
1
2
3
4
5
|
|
showMonthAfterYear
false
Initialize the datepicker with the showMonthAfterYear
option specified:
1
2
3
|
|
Get or set the showMonthAfterYear
option, after initialization:
1
2
3
4
5
|
|
showOn
"focus"
"focus"
), when a button is clicked ("button"
), or when either event occurs ("both"
).Initialize the datepicker with the showOn
option specified:
1
2
3
|
|
Get or set the showOn
option, after initialization:
1
2
3
4
5
|
|
showOptions
{}
showAnim
option, you can provide additional properties for that animation using this option.Initialize the datepicker with the showOptions
option specified:
1
2
3
|
|
Get or set the showOptions
option, after initialization:
1
2
3
4
5
|
|
showOtherMonths
false
selectOtherMonths
option.Initialize the datepicker with the showOtherMonths
option specified:
1
2
3
|
|
Get or set the showOtherMonths
option, after initialization:
1
2
3
4
5
|
|
showWeek
false
true
, a column is added to show the week of the year. The calculateWeek
option determines how the week of the year is calculated. You may also want to change the firstDay
option.Initialize the datepicker with the showWeek
option specified:
1
2
3
|
|
Get or set the showWeek
option, after initialization:
1
2
3
4
5
|
|
stepMonths
1
Initialize the datepicker with the stepMonths
option specified:
1
2
3
|
|
Get or set the stepMonths
option, after initialization:
1
2
3
4
5
|
|
weekHeader
"Wk"
showWeek
option to display this column.Initialize the datepicker with the weekHeader
option specified:
1
2
3
|
|
Get or set the weekHeader
option, after initialization:
1
2
3
4
5
|
|
yearRange
"c-10:c+10"
"-nn:+nn"
), relative to the currently selected year ("c-nn:c+nn"
), absolute ("nnnn:nnnn"
), or combinations of these formats ("nnnn:-nn"
). Note that this option only affects what appears in the drop-down, to restrict which dates may be selected use the minDate
and/or maxDate
options.Initialize the datepicker with the yearRange
option specified:
1
2
3
|
|
Get or set the yearRange
option, after initialization:
1
2
3
4
5
|
|
yearSuffix
""
Initialize the datepicker with the yearSuffix
option specified:
1
2
3
|
|
Get or set the yearSuffix
option, after initialization:
1
2
3
4
5
|
|
Methods
destroy()Returns: jQuery (plugin only)
- This method does not accept any arguments.
Invoke the destroy method:
1
|
|
dialog( date [, onSelect ] [, options ] [, pos ] )Returns: jQuery (plugin only)
-
dateThe initial date.
-
onSelectType: Function()A callback function when a date is selected. The function receives the date text and date picker instance as parameters.
-
optionsType: OptionsThe new options for the date picker.
-
posType: Number[2] or MouseEventThe position of the top/left of the dialog as
[x, y]
or aMouseEvent
that contains the coordinates. If not specified the dialog is centered on the screen.
Invoke the dialog method:
1
|
|
getDate()Returns: Date
null
if no date has been selected.- This method does not accept any arguments.
Invoke the getDate method:
1
|
|
hide()Returns: jQuery (plugin only)
- This method does not accept any arguments.
Invoke the hide method:
1
|
|
isDisabled()Returns: Boolean
- This method does not accept any arguments.
Invoke the isDisabled method:
1
|
|
option( optionName )Returns: Object
Gets the value currently associated with the specified optionName
.
Note: For options that have objects as their value, you can get the value of a specific key by using dot notation. For example, "foo.bar"
would get the value of the bar
property on the foo
option.
-
optionNameType: StringThe name of the option to get.
Invoke the method:
1
|
|
option()Returns: PlainObject
- This signature does not accept any arguments.
Invoke the method:
1
|
|
option( optionName, value )Returns: jQuery (plugin only)
Sets the value of the datepicker option associated with the specified optionName
.
Note: For options that have objects as their value, you can set the value of just one property by using dot notation for optionName
. For example, "foo.bar"
would update only the bar
property of the foo
option.
-
optionNameType: StringThe name of the option to set.
-
valueType: ObjectA value to set for the option.
Invoke the method:
1
|
|
option( options )Returns: jQuery (plugin only)
-
optionsType: ObjectA map of option-value pairs to set.
Invoke the method:
1
|
|
refresh()Returns: jQuery (plugin only)
- This method does not accept any arguments.
Invoke the refresh method:
1
|
|
setDate( date )Returns: jQuery (plugin only)
Date
object or a string in the current date format (e.g., "01/26/2009"
), a number of days from today (e.g., +7
) or a string of values and periods ("y"
for years, "m"
for months, "w"
for weeks, "d"
for days, e.g., "+1m +7d"
), or null
to clear the selected date.-
dateThe new date.
Invoke the setDate method:
1
|
|
show()Returns: jQuery (plugin only)
- This method does not accept any arguments.
Invoke the show method:
1
|
|
widget()Returns: jQuery
jQuery
object containing the datepicker.
- This method does not accept any arguments.
Invoke the widget method:
1
|
|
Example:
A simple jQuery UI Datepicker.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
|