Intl.Locale.prototype.getCollations()
The getCollations() method of Intl.Locale instances returns a list of one or more collation types for this locale.
Note: In some versions of some browsers, this method was implemented as an accessor property called collations. However, because it returns a new array on each access, it is now implemented as a method to prevent the situation of locale.collations === locale.collations returning false. Check the browser compatibility table for details.
Return value
An array of strings representing all collation types commonly used for the Locale, sorted in alphabetical order, with the standard and search values always excluded. If the Locale already has a collation, then the returned array contains that single value.
Below is a list of the supported collation types, adapted from the Unicode collation specification.
Supported collation types
-
big5han
-
Pinyin ordering for Latin, big5 charset ordering for CJK characters (for Chinese)
Warning: The big5han collation type is deprecated, not available in Firefox, Chrome or Edge.
-
compat
-
A previous version of the ordering, for compatibility (for Arabic)
-
dict
-
Dictionary style ordering (for Sinhala)
-
direct
-
Binary code point order
Warning: The direct collation type has been deprecated. Do not use.
-
ducet
-
The default Unicode collation element table order
Warning: The ducet collation type is not available to the Web. Use the und locale without a collation type specifier instead. und is the collation that is the closest to ducet.
-
emoji
-
Recommended ordering for emoji characters (for the und locale)
-
eor
-
European ordering rules (for the und locale)
-
gb2312
-
Pinyin ordering for Latin, gb2312han charset ordering for CJK characters (for Chinese)
Warning: The gb2312 collation type is deprecated, not available in Firefox, Chrome or Edge.
-
phonebk
-
Phonebook style ordering (for German)
-
phonetic
-
Phonetic ordering (sorting based on pronunciation; for Lingala)
-
pinyin
-
Pinyin ordering for Latin and for CJK characters (for Chinese)
-
reformed
-
Reformed ordering (formerly for Swedish)
-
search
-
Special collation type for string search
Warning: Do not use as a collation type, since in Intl.Collator, this collation is activated via the "search" value for the usage option. There is currently no API for substring search, so this is currently only good for filtering a list of strings by trying a full-string match of the key against each list item.
-
searchjl
-
Special collation type for Korean initial consonant search
Warning: This collation is not for sorting, even though it is made available through Intl.Collator instantiated with usage "sort" as opposed to usage "search".
-
standard
-
Default ordering for each language, except Chinese (and, previously, Swedish)
Warning: Do not use explicitly. In general, it's unnecessary to specify this explicitly and specifying this for Swedish is problematic due to the different meaning for Swedish in the past.
-
stroke
-
Pinyin ordering for Latin, stroke order for CJK characters (for Chinese)
-
trad
-
Traditional style ordering (such as in Spanish)
-
unihan
-
Radical-stroke ordering for Han characters (for Chinese, Japanese, and Korean). Pinyin ordering for Latin in the case of Chinese.
Note: The unihan collation type is not available in Chrome or Edge.
-
zhuyin
-
Pinyin ordering for Latin, zhuyin order for Bopomofo and CJK characters (for Chinese)
Obtaining supported collation types
If the Locale object doesn't have a collation already, getCollations() lists all commonly-used collation types for the given Locale. For examples of explicitly setting a collation, see collation examples.
const locale = new Intl.Locale("zh");
console.log(locale.getCollations());
Specifications
Browser compatibility
|
Desktop |
Mobile |
Server |
|
Chrome |
Edge |
Firefox |
Opera |
Safari |
Chrome Android |
Firefox for Android |
Opera Android |
Safari on IOS |
Samsung Internet |
WebView Android |
Deno |
Node.js |
getCollations |
99Implemented as an accessor property.
|
99Implemented as an accessor property.
|
No |
85Implemented as an accessor property.
|
17
15.4–previewImplemented as an accessor property.
|
99Implemented as an accessor property.
|
No |
68Implemented as an accessor property.
|
17
15.4Implemented as an accessor property.
|
18.0Implemented as an accessor property.
|
99Implemented as an accessor property.
|
1.19 |
18.0.0Implemented as an accessor property.
|