Haz tu pregunta y obtén un resumen del documento referenciando esta página y el proveedor AI de tu elección
Este documento está desactualizado, la versión base se actualizó el 16 de noviembre de 2025.
Ir a la documentación en inglésHistorial de versiones
- "Historial inicial"v5.5.1029/6/2025
El contenido de esta página ha sido traducido con una IA.
Ver la última versión del contenido original en inglésIf 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
Documentación: Función getLocalizedUrl en intlayer
Descripción
La función getLocalizedUrl genera una URL localizada añadiendo un prefijo de locale a la URL proporcionada. Maneja tanto URLs absolutas como relativas, asegurando que el prefijo de locale correcto se aplique basándose en la configuración.
Características clave:
- Solo se requieren 2 parámetros:
urlycurrentLocale - Objeto
optionsopcional conlocales,defaultLocaleymode - Utiliza la configuración de internacionalización de tu proyecto como valores por defecto
- Puede utilizarse con parámetros mínimos para casos simples o completamente personalizado para escenarios complejos
- Soporta múltiples modos de enrutamiento:
prefix-no-default,prefix-all,no-prefixysearch-params
Firma de Función
Copiar el código al portapapeles
getLocalizedUrl( url: string, // Requerido currentLocale: Locales, // Requerido options?: { // Opcional locales?: Locales[]; defaultLocale?: Locales; mode?: 'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'; }): stringParámetros
Descripción
La función getLocalizedUrl genera una URL localizada anteponiendo la URL dada con el locale especificado. Maneja tanto URLs absolutas como relativas, asegurando que se aplique el prefijo de locale correcto según la configuración.
Parámetros
url: string- Descripción: La cadena de URL original a la que se le antepondrá un locale.
- Tipo:
string
currentLocale: Locales- Descripción: El locale actual para el cual se está localizando la URL.
- Tipo:
Locales
locales: Locales[]- Descripción: Array opcional de locales soportados. Por defecto, se proporcionan los locales configurados en el proyecto.
- Tipo:
Locales[] - Por defecto:
Configuración del Proyecto
defaultLocale: Locales- Descripción: El locale por defecto para la aplicación. Por defecto, se proporciona el locale por defecto configurado en el proyecto.
- Tipo:
Locales - Por defecto:
Configuración del Proyecto
prefixDefault: boolean- Descripción: Indica si se debe anteponer el prefijo para el locale por defecto. Por defecto, se proporciona el valor configurado en el proyecto.
- Tipo:
boolean - Por defecto:
Configuración del Proyecto
Retorna
- Tipo:
string - Descripción: La URL localizada para el locale especificado.
Ejemplo de Uso
Uso Básico (Solo Parámetros Requeridos)
Cuando hayas configurado tu proyecto con configuraciones de internacionalización, puedes usar la función con solo los parámetros requeridos:
Copiar el código al portapapeles
import { getLocalizedUrl, Locales } from "intlayer";
// Usa la configuración de tu proyecto para locales, defaultLocale, y mode
getLocalizedUrl("/about", Locales.FRENCH);
// Output: "/fr/about" (asumiendo que francés es soportado y mode es 'prefix-no-default')
getLocalizedUrl("/about", Locales.ENGLISH);
// Output: "/about" o "/en/about" (dependiendo de tu configuración de mode)Uso Avanzado (Con Parámetros Opcionales)
Puedes anular la configuración predeterminada proporcionando el parámetro options opcional:
URLs Relativas
Copiar el código al portapapeles
import { getLocalizedUrl, Locales } from "intlayer";
getLocalizedUrl(
"/about",
Locales.FRENCH,
[Locales.ENGLISH, Locales.FRENCH],
Locales.ENGLISH,
false
);
// Salida: "/fr/about" para el locale francés
// Salida: "/about" para el locale por defecto (inglés)Anulación Parcial de Configuración
También puede proporcionar solo algunos de los parámetros opcionales. La función utilizará la configuración de su proyecto para los parámetros que no especifique:
Copiar el código al portapapeles
import { getLocalizedUrl, Locales } from "intlayer";// Solo anular los locales, usar la configuración del proyecto para defaultLocale y modegetLocalizedUrl("/about", Locales.SPANISH, { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],});// Solo anular mode, usar la configuración del proyecto para locales y defaultLocalegetLocalizedUrl("/about", Locales.ENGLISH, { mode: "prefix-all", // Forzar prefijo para todos los locales incluyendo el predeterminado});// Anular múltiples opcionesgetLocalizedUrl("/about", Locales.FRENCH, { defaultLocale: Locales.ENGLISH, mode: "search-params", // Usar parámetros de consulta: /about?locale=fr});URLs Absolutas
Copiar el código al portapapeles
getLocalizedUrl( "https://example.com/about", Locales.FRENCH, // Locale Actual [Locales.ENGLISH, Locales.FRENCH], // Locales Soportados Locales.ENGLISH, // Locale por Defecto false // Prefijar el Locale por Defecto); // Salida: "https://example.com/fr/about" para el francésgetLocalizedUrl( "https://example.com/about", Locales.ENGLISH, // Locale Actual [Locales.ENGLISH, Locales.FRENCH], // Locales Soportados Locales.ENGLISH, // Locale por Defecto false // Prefijar el Locale por Defecto); // Salida: "https://example.com/about" para el inglésgetLocalizedUrl( "https://example.com/about", Locales.ENGLISH, // Locale Actual [Locales.ENGLISH, Locales.FRENCH], // Locales Soportados Locales.ENGLISH, // Locale por Defecto true // Prefijar el Locale por Defecto); // Salida: "https://example.com/en/about" para el inglésLocale No Soportado
Copiar el código al portapapeles
getLocalizedUrl( "/about", Locales.ITALIAN, // Locale Actual [Locales.ENGLISH, Locales.FRENCH], // Locales Soportados Locales.ENGLISH // Locale por Defecto); // Salida: "/about" (no se aplica prefijo para locales no soportados)Casos Especiales
Sin Segmento de Locale:
- Si la URL no contiene ningún segmento de locale, la función añade de forma segura el locale apropiado como prefijo.
Locale por Defecto:
- Cuando
prefixDefaultesfalse, la función no añade prefijo a la URL para el locale por defecto.
- Cuando
Locales No Soportados:
- Para locales que no están listados en
locales, la función no aplica ningún prefijo.
- Para locales que no están listados en
Uso en Aplicaciones
En una aplicación multilingüe, configurar los ajustes de internacionalización con locales y defaultLocale es fundamental para asegurar que se muestre el idioma correcto. A continuación, se muestra un ejemplo de cómo getLocalizedUrl puede usarse en la configuración de una aplicación:
Copiar el código al portapapeles
import { Locales, type IntlayerConfig } from "intlayer";
// Configuración para locales soportados y locale por defecto
export default {
internationalization: {
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
defaultLocale: Locales.ENGLISH,
},
} satisfies IntlayerConfig;
export default config;La configuración anterior asegura que la aplicación reconozca ENGLISH, FRENCH y SPANISH como idiomas soportados y utilice ENGLISH como idioma predeterminado.
Usando esta configuración, la función getLocalizedUrl puede generar dinámicamente URLs localizadas basadas en la preferencia de idioma del usuario:
Copiar el código al portapapeles
getLocalizedUrl("/about", Locales.FRENCH); // Salida: "/fr/about"getLocalizedUrl("/about", Locales.SPANISH); // Salida: "/es/about"getLocalizedUrl("/about", Locales.ENGLISH); // Salida: "/about"Al integrar getLocalizedUrl, los desarrolladores pueden mantener estructuras de URL consistentes en múltiples idiomas, mejorando tanto la experiencia del usuario como el SEO.