文档: getMultilingualUrls 函数在 intlayer
描述:
getMultilingualUrls 函数通过使用每个支持的语言环境前缀给定的 URL 来生成多语言 URL 的映射。它可以处理绝对和相对 URL,基于提供的配置或默认值应用适当的语言环境前缀。
参数:
url: string
- 描述: 原始 URL 字符串,将使用语言环境进行前缀处理。
- 类型: string
locales: Locales[]
- 描述: 可选的支持的语言环境数组。默认为项目中配置的语言环境。
- 类型: Locales[]
- 默认: localesDefault
defaultLocale: Locales
- 描述: 应用程序的默认语言环境。默认为项目中配置的默认语言环境。
- 类型: Locales
- 默认: defaultLocaleDefault
prefixDefault: boolean
- 描述: 是否为默认语言环境添加前缀。默认为项目中配置的值。
- 类型: boolean
- 默认: prefixDefaultDefault
返回:
- 类型: IConfigLocales<string>
- 描述: 将每个语言环境映射到其对应的多语言 URL 的对象。
示例用法:
相对 URL:
typescript
import { getMultilingualUrls, Locales } from "intlayer";getMultilingualUrls( "/dashboard", [Locales.ENGLISH, Locales.FRENCH], Locales.ENGLISH, false);// 输出: {// en: "/dashboard",// fr: "/fr/dashboard"// }
绝对 URL:
typescript
getMultilingualUrls( "https://example.com/dashboard", [Locales.ENGLISH, Locales.FRENCH], Locales.ENGLISH, true);// 输出: {// en: "https://example.com/en/dashboard",// fr: "https://example.com/fr/dashboard"// }
边缘案例:
没有语言环境段:
- 该函数在生成多语言映射之前,从 URL 中移除任何现有的语言环境段。
默认语言环境:
- 当 prefixDefault 为 false 时,函数不为默认语言环境前缀 URL。
不支持的语言环境:
- 仅考虑 locales 数组中提供的语言环境以生成 URL。
在应用程序中的用法:
在多语言应用程序中,使用 locales 和 defaultLocale 配置国际化设置对于确保正确显示语言至关重要。以下是如何在应用程序设置中使用 getMultilingualUrls 的示例:
tsx
import { Locales, type IntlayerConfig } from "intlayer";// 支持的语言环境和默认语言环境的配置export default { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, },} satisfies IntlayerConfig;export default config;
上述配置确保应用程序识别 ENGLISH、FRENCH 和 SPANISH 为支持的语言,并使用 ENGLISH 作为后备语言。
使用此配置,getMultilingualUrls 函数可以根据应用程序支持的语言动态生成多语言 URL 映射:
typescript
getMultilingualUrls( "/dashboard", [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], Locales.ENGLISH);// 输出:// {// en: "/dashboard",// fr: "/fr/dashboard",// es: "/es/dashboard"// }getMultilingualUrls( "https://example.com/dashboard", [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], Locales.ENGLISH, true);// 输出:// {// en: "https://example.com/en/dashboard",// fr: "https://example.com/fr/dashboard",// es: "https://example.com/es/dashboard"// }
通过集成 getMultilingualUrls,开发人员可以在多种语言之间维持一致的 URL 结构,增强用户体验和SEO。
如果您有改善此文档的想法,请随时通过在GitHub上提交拉取请求来贡献。
文档的 GitHub 链接