The Intl.DateTimeFormat
When the Intl.DateTimeFormat
function is called with optional arguments locales and options, the following steps are taken:
The abstract operation InitializeDateTimeFormat accepts the arguments dateTimeFormat (which must be an object), locales, and options. It initializes dateTimeFormat as a DateTimeFormat object. This abstract operation functions as follows:
The following algorithm refers to the type
nonterminal from UTS 35's Unicode Locale Identifier grammar.
type
nonterminal, throw a type
nonterminal, throw a
The Intl.DateTimeFormat
The value of Intl.DateTimeFormat.prototype
is
This property has the attributes { [[Writable]]:
When the supportedLocalesOf
method is called with arguments locales and options, the following steps are taken:
The value of the [[AvailableLocales]] internal slot is implementation-defined within the constraints described in
The value of the [[RelevantExtensionKeys]] internal slot is «
The value of the [[LocaleData]] internal slot is implementation-defined within the constraints described in
Range Pattern Field | Pattern String Field |
---|---|
[[Era]] | |
[[Year]] | |
[[Month]] | |
[[Day]] | |
[[AmPm]] | |
[[DayPeriod]] | |
[[Hour]] | |
[[Minute]] | |
[[Second]] | |
[[FractionalSecondDigits]] |
The Intl.DateTimeFormat prototype object is itself an ordinary object. %DateTimeFormat.prototype% is not an Intl.DateTimeFormat instance and does not have an [[InitializedDateTimeFormat]] internal slot or any of the other internal slots of Intl.DateTimeFormat instance objects.
The initial value of Intl.DateTimeFormat.prototype.constructor
is
The initial value of the @@toStringTag property is the String value
This property has the attributes { [[Writable]]:
Intl.DateTimeFormat.prototype.format is an
Array.prototype.map
or other functions.
This is considered a historical artefact, as part of a convention which is no longer followed for new features, but is preserved to maintain compatibility with existing programs.
When the formatToParts
method is called with an argument date, the following steps are taken:
When the formatRange
method is called with arguments startDate and endDate, the following steps are taken:
When the formatRangeToParts
method is called with arguments startDate and endDate, the following steps are taken:
This function provides access to the locale and options computed during initialization of the object.
Internal Slot | Property |
---|---|
[[Locale]] | |
[[Calendar]] | |
[[NumberingSystem]] | |
[[TimeZone]] | |
[[HourCycle]] | |
[[Weekday]] | |
[[EraDisplay]] | |
[[Era]] | |
[[Year]] | |
[[Month]] | |
[[Day]] | |
[[DayPeriod]] | |
[[Hour]] | |
[[Minute]] | |
[[Second]] | |
[[FractionalSecondDigits]] | |
[[TimeZoneName]] | |
[[DateStyle]] | |
[[TimeStyle]] |
For web compatibility reasons, if the property
Intl.DateTimeFormat instances are ordinary objects that inherit properties from
Intl.DateTimeFormat instances have an [[InitializedDateTimeFormat]] internal slot.
Intl.DateTimeFormat instances also have several internal slots that are computed by the
Finally, Intl.DateTimeFormat instances have a [[BoundFormat]] internal slot that caches the function returned by the format accessor (
Several DateTimeFormat algorithms use values from the following table, which provides internal slots, property names and allowable values for the components of date and time formats:
Internal Slot | Property | Values |
---|---|---|
[[Weekday]] | ||
[[Era]] | ||
[[Year]] | ||
[[Month]] | ||
[[Day]] | ||
[[DayPeriod]] | ||
[[Hour]] | ||
[[Minute]] | ||
[[Second]] | ||
[[FractionalSecondDigits]] | ||
[[TimeZoneName]] |
When the ToDateTimeOptions abstract operation is called with arguments options, required, and defaults, the following steps are taken:
The DateTimeStyleFormat abstract operation accepts arguments dateStyle and timeStyle, which are each either
When the BasicFormatMatcher abstract operation is called with two arguments options and formats, the following steps are taken:
When the BestFitFormatMatcher abstract operation is called with two arguments options and formats, it performs implementation dependent steps, which should return a set of component representations that a typical user of the selected locale would perceive as at least as good as the one returned by
A DateTime format function is an anonymous built-in function that has a [[DateTimeFormat]] internal slot.
When a DateTime format function F is called with optional argument date, the following steps are taken:
The
The FormatDateTimePattern abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat), patternParts (which is a list of Records as returned by PartitionPattern), x (which must be a
The PartitionDateTimePattern abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat) and x (which must be a
The FormatDateTime abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat) and x (which must be a
The FormatDateTimeToParts abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat) and x (which must be a
The PartitionDateTimeRangePattern abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat), x (which must be a
The FormatDateTimeRange abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat), x (which must be a
The FormatDateTimeRangeToParts abstract operation is called with arguments dateTimeFormat (which must be an object initialized as a DateTimeFormat), x (which must be a
Field | Value Calculation for Gregorian Calendar |
---|---|
[[Weekday]] | |
[[Era]] | Let year be |
[[Year]] | |
[[RelatedYear]] | |
[[YearName]] | |
[[Month]] | |
[[Day]] | |
[[Hour]] | |
[[Minute]] | |
[[Second]] | |
[[Millisecond]] | |
[[InDST]] | Calculate |
The UnwrapDateTimeFormat abstract operation returns the DateTimeFormat instance
of its input object, which is either the value itself or a value associated
with it by