Expo 本地化
一个提供原生用户本地化信息接口的库。
For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.
expo-localization 允许你本地化你的应用,为特定地区、语言或文化自定义体验。它还提供对原生设备上区域设置数据的访问。使用诸如 lingui-js、react-i18next、react-intl、i18n-js 或 react-native-intlayer 之类的本地化库,并结合 expo-localization,将使你能够为用户创建非常易用的体验。
安装
- npx expo install expo-localizationIf you are installing this in an existing React Native app, make sure to install expo in your project.
在 app 配置中进行配置
如果你在项目中使用 config plugin(Continuous Native Generation (CNG)),可以使用 expo-localization 内置的 config plugin 来配置它。该插件允许你配置一些无法在运行时设置的属性,这些属性需要构建新的应用二进制文件后才会生效。如果你的应用不使用 CNG,那么你需要手动配置该库。
Example app.json with config plugin
{ "expo": { "plugins": ["expo-localization"] } }
用法
有关使用 expo-localization 以及添加对从右到左语言支持的更多信息,请参阅 Localization 指南。
API
import { getLocales, getCalendars } from 'expo-localization';
行为
你可以使用同步的 getLocales() 和 getCalendars() 方法来获取用户设备的区域设置。在 iOS 上,只要应用正在运行,结果将保持不变。
在 Android 上,用户可以在设置中更改区域设置偏好,而无需重启应用。为了保持本地化信息的最新状态,你可以在应用每次回到前台时重新运行 getLocales() 和 getCalendars() 方法。使用 AppState 来检测这一点。
Hooks
A hook providing a list of user's preferred calendars, returned as an array of objects of type Calendar.
Guaranteed to contain at least 1 element.
For now always returns a single element, but it's likely to return a user preference list on some platforms in the future.
If the OS settings change, the hook will rerender with a new list of calendars.
Calendar[]Example
[{ "calendar": "gregory", "timeZone": "Europe/Warsaw", "uses24hourClock": true, "firstWeekday": 1 }]
A hook providing a list of user's locales, returned as an array of objects of type Locale.
Guaranteed to contain at least 1 element.
These are returned in the order the user defines in their device settings.
On the web currency and measurements systems are not provided, instead returned as null.
If needed, you can infer them from the current region using a lookup table.
If the OS settings change, the hook will rerender with a new list of locales.
Locale[]Example
[{ "languageTag": "pl-PL", "languageCode": "pl", "textDirection": "ltr", "digitGroupingSeparator": " ", "decimalSeparator": ",", "measurementSystem": "metric", "currencyCode": "PLN", "currencySymbol": "zł", "regionCode": "PL", "temperatureUnit": "celsius" }]
Methods
List of user's preferred calendars, returned as an array of objects of type Calendar.
Guaranteed to contain at least 1 element.
For now always returns a single element, but it's likely to return a user preference list on some platforms in the future.
Calendar[]Example
[{ "calendar": "gregory", "timeZone": "Europe/Warsaw", "uses24hourClock": true, "firstWeekday": 1 }]
List of user's locales, returned as an array of objects of type Locale.
Guaranteed to contain at least 1 element.
These are returned in the order the user defines in their device settings.
On the web currency and measurements systems are not provided, instead returned as null.
If needed, you can infer them from the current region using a lookup table.
Locale[]Example
[{ "languageTag": "pl-PL", "languageCode": "pl", "textDirection": "ltr", "digitGroupingSeparator": " ", "decimalSeparator": ",", "measurementSystem": "metric", "currencyCode": "PLN", "currencySymbol": "zł", "regionCode": "PL", "temperatureUnit": "celsius" }]
Types
| Property | Type | Description |
|---|---|---|
| calendar | CalendarIdentifier | null | The calendar identifier, one of Unicode calendar types. On Android is limited to one of device's available calendar types. On iOS uses calendar identifiers, but maps them to the corresponding Unicode types, will also never contain |
| firstWeekday | Weekday | null | |
| timeZone | string | null | Time zone for the calendar. Can be Example
|
| uses24hourClock | boolean | null |
| Property | Type | Description |
|---|---|---|
| currencyCode | string | null | Currency code for the locale.
On iOS, it's the currency code from the Example
|
| currencySymbol | string | null | Currency symbol for the currency specified by Example
|
| decimalSeparator | string | null | Decimal separator used for formatting numbers with fractional parts. Example
|
| digitGroupingSeparator | string | null | Digit grouping separator used for formatting large numbers. Example
|
| languageCode | string | null | An IETF BCP 47 language tag without the region code. Example
|
| languageCurrencyCode | string | null | Currency code for the locale.
On iOS, it's the currency code for the current locale in the list, not the device region.
On Android, it's equal to Example
|
| languageCurrencySymbol | string | null | Currency symbol for the currency specified by Example
|
| languageRegionCode | string | null | The region code for the preferred language. When the language is not region-specific, it returns the same value as Example
|
| languageScriptCode | string | null | An ISO 15924 4-letter script code. On Android and Web, it may be Example
|
| languageTag | string | An IETF BCP 47 language tag with a region code. Example
|
| measurementSystem | 'metric' | 'us' | 'uk' | null | The measurement system used in the locale.
Is |
| regionCode | string | null | The region code for your device that comes from the Region setting under Language & Region on iOS, Region settings on Android and is parsed from locale on Web (can be Example
|
| temperatureUnit | 'celsius' | 'fahrenheit' | null | The temperature unit used in the locale.
Returns |
| textDirection | 'ltr' | 'rtl' | null |
Enums
The calendar identifier, one of Unicode calendar types.
Gregorian calendar is aliased and can be referred to as both CalendarIdentifier.GREGORIAN and CalendarIdentifier.GREGORY.
CalendarIdentifier.ETHIOAA = "ethioaa"Ethiopic calendar, Amete Alem (epoch approx. 5493 B.C.E)
CalendarIdentifier.ETHIOPIC = "ethiopic"Ethiopic calendar, Amete Mihret (epoch approx, 8 C.E.)
CalendarIdentifier.ISLAMIC_CIVIL = "islamic-civil"Islamic calendar, tabular (intercalary years [2,5,7,10,13,16,18,21,24,26,29] - civil epoch)
CalendarIdentifier.ISLAMIC_TBLA = "islamic-tbla"Islamic calendar, tabular (intercalary years [2,5,7,10,13,16,18,21,24,26,29] - astronomical epoch)
CalendarIdentifier.ISLAMIC_UMALQURA = "islamic-umalqura"Islamic calendar, Umm al-Qura
CalendarIdentifier.ISO8601 = "iso8601"ISO calendar (Gregorian calendar using the ISO 8601 calendar week rules)
An enum mapping days of the week in Gregorian calendar to their index as returned by the firstWeekday property.