使用您最喜欢的AI助手总结文档,并引用此页面和AI提供商
此页面的内容已使用 AI 翻译。
查看英文原文的最新版本If you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
文档:intlayer 中的 getLocalizedUrl 函数
描述
getLocalizedUrl 函数通过在给定的 URL 前添加指定的语言环境前缀来生成本地化的 URL。它可以处理绝对 URL 和相对 URL,确保根据配置应用正确的语言环境前缀。
函数签名
复制代码到剪贴板
getLocalizedUrl( url: string, // 必需 currentLocale: Locales, // 必需 options?: { // 可选 locales?: Locales[]; defaultLocale?: Locales; mode?: 'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'; }): string参数
必需参数
url: string- Description: 要用 locale 前缀的原始 URL 字符串。
- Type:
string - Required: Yes
currentLocale: Locales- Description: 正在本地化 URL 的当前 locale。
- Type:
Locales - Required: Yes
参数
url: string- 描述:需要添加语言环境前缀的原始 URL 字符串。
- 类型:
string
currentLocale: Locales- 描述:当前正在本地化的语言环境。
- 类型:
Locales
locales: Locales[]- 描述:可选的支持语言环境数组。默认情况下,提供项目中配置的语言环境。
- 类型:
Locales[] - 默认值:
项目配置
defaultLocale: Locales- 描述:应用程序的默认语言环境。默认情况下,提供项目中配置的默认语言环境。
- 类型:
Locales - 默认值:
项目配置
prefixDefault: boolean- 描述:是否为默认语言环境的 URL 添加前缀。默认情况下,提供项目中配置的值。
- 类型:
boolean - 默认值:
项目配置
返回值
- 类型:
string - 描述: 指定语言环境的本地化 URL。
示例用法
基本用法(仅需必需参数)
当你使用国际化设置配置项目后,可以仅使用必需参数来调用该函数:
复制代码到剪贴板
import { getLocalizedUrl, Locales } from "intlayer";
// 使用你的项目配置中的 locales、defaultLocale 和 mode
getLocalizedUrl("/about", Locales.FRENCH);
// Output: "/fr/about" (假设支持法语且 mode 设置为 'prefix-no-default')
getLocalizedUrl("/about", Locales.ENGLISH);
// Output: "/about" 或 "/en/about" (取决于你的 mode 设置)高级用法(带可选参数)
您可以通过提供可选的 options 参数来覆盖默认配置:
相对 URL
复制代码到剪贴板
import { getLocalizedUrl, Locales } from "intlayer";
getLocalizedUrl(
"/about",
Locales.FRENCH,
[Locales.ENGLISH, Locales.FRENCH],
Locales.ENGLISH,
false
);
// 输出: 对于法语环境为 "/fr/about"
// 输出: 对于默认(英语)环境为 "/about"部分配置覆盖
您也可以仅提供部分可选参数。该函数将对您未指定的任何参数使用您的项目配置:
复制代码到剪贴板
import { getLocalizedUrl, Locales } from "intlayer";// 仅覆盖 locales,使用项目配置中的 defaultLocale 和 modegetLocalizedUrl("/about", Locales.SPANISH, { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],});// 仅覆盖 mode,使用项目配置中的 locales 和 defaultLocalegetLocalizedUrl("/about", Locales.ENGLISH, { mode: "prefix-all", // 对所有语言(包括默认语言)强制添加前缀});// 覆盖多个选项getLocalizedUrl("/about", Locales.FRENCH, { defaultLocale: Locales.ENGLISH, mode: "search-params", // 使用查询参数:/about?locale=fr});绝对 URL
复制代码到剪贴板
getLocalizedUrl( "https://example.com/about", Locales.FRENCH, // 当前区域 [Locales.ENGLISH, Locales.FRENCH], // 支持的区域 Locales.ENGLISH, // 默认区域 false // 是否为默认语言添加前缀); // 输出: "https://example.com/fr/about" (法语)getLocalizedUrl( "https://example.com/about", Locales.ENGLISH, // 当前语言 [Locales.ENGLISH, Locales.FRENCH], // 支持的语言 Locales.ENGLISH, // 默认语言 false // 是否为默认语言添加前缀); // 输出: "https://example.com/about" (英语)getLocalizedUrl( "https://example.com/about", Locales.ENGLISH, // 当前语言 [Locales.ENGLISH, Locales.FRENCH], // 支持的语言 Locales.ENGLISH, // 默认语言 true // 是否为默认语言添加前缀); // 输出: "https://example.com/en/about" (英语)不支持的语言
复制代码到剪贴板
getLocalizedUrl( "/about", Locales.ITALIAN, // 当前语言 [Locales.ENGLISH, Locales.FRENCH], // 支持的语言环境 Locales.ENGLISH // 默认语言环境); // 输出: "/about"(对于不支持的语言环境不添加前缀)边缘情况
无语言环境段:
- 如果 URL 中不包含任何语言环境段,函数会安全地添加适当的语言环境前缀。
默认语言环境:
- 当
prefixDefault为false时,函数不会为默认语言环境添加前缀。
- 当
不支持的语言环境:
- 对于未列在
locales中的语言环境,函数不会添加任何前缀。
- 对于未列在
在应用中的使用
在多语言应用程序中,使用 locales 和 defaultLocale 配置国际化设置对于确保显示正确的语言至关重要。以下是如何在应用程序设置中使用 getLocalizedUrl 的示例:
复制代码到剪贴板
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 作为回退语言。
使用此配置,getLocalizedUrl 函数可以根据用户的语言偏好动态生成本地化 URL:
复制代码到剪贴板
getLocalizedUrl("/about", Locales.FRENCH); // 输出: "/fr/about"getLocalizedUrl("/about", Locales.SPANISH); // 输出: "/es/about"getLocalizedUrl("/about", Locales.ENGLISH); // 输出: "/about"通过集成 getLocalizedUrl,开发者可以在多语言环境中保持一致的 URL 结构,提升用户体验和 SEO 效果。