Intl.PluralRules.supportedLocalesOf()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2019.
The Intl.PluralRules.supportedLocalesOf()
static method returns an array containing those of the provided locales that are supported in plural rules without having to fall back to the runtime's default locale.
Try it
Syntax
Intl.PluralRules.supportedLocalesOf(locales)
Intl.PluralRules.supportedLocalesOf(locales, options)
Parameters
locales
-
A string with a BCP 47 language tag, or an array of such strings. For the general form and interpretation of the
locales
argument, see the parameter description on theIntl
main page. options
Optional-
An object that may have the following property:
localeMatcher
-
The locale matching algorithm to use. Possible values are
"lookup"
and"best fit"
; the default is"best fit"
. For information about this option, see the Intl page.
Return value
An array of strings representing a subset of the given locale tags that are supported in plural rules without having to fall back to the runtime's default locale.
Examples
Using supportedLocalesOf()
Assuming a runtime that supports Indonesian and German but not Balinese in plural rules, supportedLocalesOf
returns the Indonesian and German language tags unchanged, even though pinyin
collation is neither relevant to plural rules nor used with Indonesian, and a specialized German for Indonesia is unlikely to be supported. Note the specification of the "lookup"
algorithm here — a "best fit"
matcher might decide that Indonesian is an adequate match for Balinese since most Balinese speakers also understand Indonesian, and therefore return the Balinese language tag as well.
const locales = ["ban", "id-u-co-pinyin", "de-ID"];
const options = { localeMatcher: "lookup" };
console.log(Intl.PluralRules.supportedLocalesOf(locales, options));
// ["id-u-co-pinyin", "de-ID"]
Specifications
Specification |
---|
ECMAScript Internationalization API Specification # sec-intl.pluralrules.supportedlocalesof |
Browser compatibility
BCD tables only load in the browser