The Intl.Locale.prototype.maximize()
method gets the most likely values for the language, script, and region of the locale based on existing values.
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
Syntax
locale.maximize()
Return value
A Add Likely Subtags algorithm executed against
. locale.baseName
Description
Sometimes, it is convenient to be able to identify the most likely locale language identifier subtags based on an incomplete langauage ID. The Add Likely Subtags algorithm gives us this functionality. For instance, given the language ID "en", the algorithm would return "en-Latn-US", since English can only be written in the Latin script, and is most likely to be used in the United States, as it is the largest English-speaking country in the world. This functionality is provided to JavaScript programmers via the maximize()
method. maximize()
only affects the main subtags that comprise the language identifier: language, script, and region subtags. Other subtags after the "-u" in the locale indentifier are called extension subtags and are not affected by the maximize()
method. Examples of these subtags include Locale.hourCycle
, Locale.calendar
, and Locale.numeric
.
Examples
let myLocale = new Intl.Locale("fr", {hourCycle: "h24", calendar: "gregory"}); console.log(myLocale.baseName); // Prints "fr" console.log(myLocale.toString()); // Prints "fr-u-ca-gregory-hc-h24" let myLocMaximized = myLocale.maximize(); // Prints "fr-Latn-FR". The "Latn" and "FR" tags are added, //since French is only written in the Latin script and is most likely to be spoken in France. console.log(myLocMaximized.baseName); // Prints "fr-Latn-FR-u-ca-gregory-hc-h24". Notice that the extension tags (after "-u") remain unchanged. console.log(myLocMaximized.toString());
Specifications
Specification | Status | Comment |
---|---|---|
Intl.Locale.prototype.maximize proposal |
Browser compatibility
Desktop | Mobile | Server | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
maximize |
Chrome Full support 74 | Edge No support No | Firefox No support No | IE No support No | Opera No support No | Safari No support No | WebView Android Full support 74 | Chrome Android Full support 74 | Firefox Android No support No | Opera Android No support No | Safari iOS No support No | Samsung Internet Android No support No | nodejs No support No |
Legend
- Full support
- Full support
- No support
- No support