@intlayer/docs 8.6.0 → 8.6.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/doc.cjs.map +1 -1
- package/dist/cjs/generated/docs.entry.cjs +60 -0
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/esm/doc.mjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +60 -0
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/types/doc.d.ts.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +3 -0
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/docs/ar/cli/index.md +54 -42
- package/docs/ar/cli/init.md +32 -20
- package/docs/ar/cli/standalone.md +91 -0
- package/docs/ar/configuration.md +39 -7
- package/docs/ar/custom_domains.md +250 -0
- package/docs/ar/intlayer_with_tanstack+solid.md +14 -33
- package/docs/ar/intlayer_with_tanstack.md +25 -16
- package/docs/ar/intlayer_with_vanilla.md +506 -0
- package/docs/bn/cli/index.md +195 -0
- package/docs/bn/cli/init.md +96 -0
- package/docs/bn/cli/standalone.md +91 -0
- package/docs/bn/configuration.md +46 -14
- package/docs/bn/custom_domains.md +250 -0
- package/docs/bn/intlayer_with_vanilla.md +506 -0
- package/docs/cs/cli/index.md +195 -0
- package/docs/cs/cli/init.md +96 -0
- package/docs/cs/cli/standalone.md +91 -0
- package/docs/cs/configuration.md +46 -7
- package/docs/cs/custom_domains.md +250 -0
- package/docs/cs/intlayer_with_vanilla.md +506 -0
- package/docs/de/cli/index.md +53 -41
- package/docs/de/cli/standalone.md +91 -0
- package/docs/de/configuration.md +46 -7
- package/docs/de/custom_domains.md +250 -0
- package/docs/de/intlayer_with_tanstack+solid.md +15 -36
- package/docs/de/intlayer_with_tanstack.md +25 -16
- package/docs/de/intlayer_with_vanilla.md +506 -0
- package/docs/en/bundle_optimization.md +288 -23
- package/docs/en/cli/index.md +6 -1
- package/docs/en/cli/init.md +13 -1
- package/docs/en/cli/standalone.md +91 -0
- package/docs/en/configuration.md +46 -7
- package/docs/en/custom_domains.md +245 -0
- package/docs/en/intlayer_with_tanstack+solid.md +15 -36
- package/docs/en/intlayer_with_tanstack.md +25 -16
- package/docs/en/intlayer_with_vanilla.md +506 -0
- package/docs/en-GB/cli/index.md +56 -44
- package/docs/en-GB/cli/init.md +28 -21
- package/docs/en-GB/cli/standalone.md +91 -0
- package/docs/en-GB/configuration.md +53 -14
- package/docs/en-GB/custom_domains.md +250 -0
- package/docs/en-GB/intlayer_with_tanstack+solid.md +15 -36
- package/docs/en-GB/intlayer_with_tanstack.md +25 -16
- package/docs/en-GB/intlayer_with_vanilla.md +506 -0
- package/docs/es/cli/index.md +65 -53
- package/docs/es/cli/init.md +33 -21
- package/docs/es/cli/standalone.md +91 -0
- package/docs/es/configuration.md +39 -1
- package/docs/es/custom_domains.md +250 -0
- package/docs/es/intlayer_with_tanstack+solid.md +15 -36
- package/docs/es/intlayer_with_tanstack.md +25 -16
- package/docs/es/intlayer_with_vanilla.md +506 -0
- package/docs/fr/cli/index.md +43 -31
- package/docs/fr/cli/init.md +37 -25
- package/docs/fr/cli/standalone.md +91 -0
- package/docs/fr/configuration.md +46 -7
- package/docs/fr/custom_domains.md +250 -0
- package/docs/fr/intlayer_with_tanstack+solid.md +15 -36
- package/docs/fr/intlayer_with_tanstack.md +25 -16
- package/docs/fr/intlayer_with_vanilla.md +506 -0
- package/docs/hi/cli/index.md +71 -59
- package/docs/hi/cli/init.md +37 -33
- package/docs/hi/cli/standalone.md +91 -0
- package/docs/hi/configuration.md +39 -7
- package/docs/hi/custom_domains.md +250 -0
- package/docs/hi/intlayer_with_tanstack+solid.md +14 -33
- package/docs/hi/intlayer_with_tanstack.md +25 -16
- package/docs/hi/intlayer_with_vanilla.md +506 -0
- package/docs/id/cli/index.md +59 -47
- package/docs/id/cli/init.md +32 -25
- package/docs/id/cli/standalone.md +91 -0
- package/docs/id/configuration.md +46 -7
- package/docs/id/custom_domains.md +250 -0
- package/docs/id/intlayer_with_tanstack+solid.md +14 -33
- package/docs/id/intlayer_with_tanstack.md +25 -16
- package/docs/id/intlayer_with_vanilla.md +506 -0
- package/docs/it/cli/index.md +58 -41
- package/docs/it/cli/init.md +37 -38
- package/docs/it/cli/standalone.md +91 -0
- package/docs/it/configuration.md +46 -7
- package/docs/it/custom_domains.md +250 -0
- package/docs/it/intlayer_with_tanstack+solid.md +15 -36
- package/docs/it/intlayer_with_tanstack.md +25 -16
- package/docs/it/intlayer_with_vanilla.md +506 -0
- package/docs/ja/cli/index.md +59 -47
- package/docs/ja/cli/init.md +36 -24
- package/docs/ja/cli/standalone.md +91 -0
- package/docs/ja/configuration.md +46 -7
- package/docs/ja/custom_domains.md +250 -0
- package/docs/ja/intlayer_with_tanstack+solid.md +15 -36
- package/docs/ja/intlayer_with_tanstack.md +25 -16
- package/docs/ja/intlayer_with_vanilla.md +506 -0
- package/docs/ko/cli/index.md +58 -46
- package/docs/ko/cli/init.md +39 -35
- package/docs/ko/cli/standalone.md +91 -0
- package/docs/ko/configuration.md +47 -8
- package/docs/ko/custom_domains.md +250 -0
- package/docs/ko/intlayer_with_tanstack+solid.md +15 -36
- package/docs/ko/intlayer_with_tanstack.md +25 -16
- package/docs/ko/intlayer_with_vanilla.md +506 -0
- package/docs/nl/cli/index.md +195 -0
- package/docs/nl/cli/init.md +96 -0
- package/docs/nl/cli/standalone.md +91 -0
- package/docs/nl/configuration.md +46 -7
- package/docs/nl/custom_domains.md +250 -0
- package/docs/nl/intlayer_with_vanilla.md +506 -0
- package/docs/pl/cli/index.md +56 -44
- package/docs/pl/cli/init.md +36 -32
- package/docs/pl/cli/standalone.md +91 -0
- package/docs/pl/configuration.md +46 -7
- package/docs/pl/custom_domains.md +250 -0
- package/docs/pl/intlayer_with_tanstack+solid.md +14 -33
- package/docs/pl/intlayer_with_tanstack.md +25 -16
- package/docs/pl/intlayer_with_vanilla.md +506 -0
- package/docs/pt/cli/index.md +64 -52
- package/docs/pt/cli/init.md +35 -31
- package/docs/pt/cli/standalone.md +91 -0
- package/docs/pt/configuration.md +46 -7
- package/docs/pt/custom_domains.md +250 -0
- package/docs/pt/intlayer_with_tanstack+solid.md +15 -36
- package/docs/pt/intlayer_with_tanstack.md +25 -16
- package/docs/pt/intlayer_with_vanilla.md +506 -0
- package/docs/ru/cli/index.md +54 -42
- package/docs/ru/cli/init.md +31 -27
- package/docs/ru/cli/standalone.md +91 -0
- package/docs/ru/configuration.md +46 -7
- package/docs/ru/custom_domains.md +250 -0
- package/docs/ru/intlayer_with_tanstack+solid.md +15 -36
- package/docs/ru/intlayer_with_tanstack.md +25 -16
- package/docs/ru/intlayer_with_vanilla.md +506 -0
- package/docs/tr/cli/index.md +64 -52
- package/docs/tr/cli/init.md +37 -30
- package/docs/tr/cli/standalone.md +91 -0
- package/docs/tr/configuration.md +46 -7
- package/docs/tr/custom_domains.md +250 -0
- package/docs/tr/intlayer_with_tanstack+solid.md +14 -33
- package/docs/tr/intlayer_with_tanstack.md +25 -16
- package/docs/tr/intlayer_with_vanilla.md +506 -0
- package/docs/uk/cli/index.md +60 -55
- package/docs/uk/cli/init.md +32 -20
- package/docs/uk/cli/standalone.md +91 -0
- package/docs/uk/configuration.md +46 -7
- package/docs/uk/custom_domains.md +250 -0
- package/docs/uk/intlayer_with_tanstack+solid.md +14 -33
- package/docs/uk/intlayer_with_tanstack.md +25 -16
- package/docs/uk/intlayer_with_vanilla.md +506 -0
- package/docs/ur/cli/index.md +195 -0
- package/docs/ur/cli/init.md +96 -0
- package/docs/ur/cli/standalone.md +91 -0
- package/docs/ur/configuration.md +46 -7
- package/docs/ur/custom_domains.md +250 -0
- package/docs/ur/intlayer_with_vanilla.md +506 -0
- package/docs/vi/cli/index.md +72 -61
- package/docs/vi/cli/init.md +33 -21
- package/docs/vi/cli/standalone.md +91 -0
- package/docs/vi/configuration.md +46 -7
- package/docs/vi/custom_domains.md +250 -0
- package/docs/vi/intlayer_with_tanstack+solid.md +14 -33
- package/docs/vi/intlayer_with_tanstack.md +25 -16
- package/docs/vi/intlayer_with_vanilla.md +506 -0
- package/docs/zh/cli/index.md +56 -49
- package/docs/zh/cli/init.md +30 -18
- package/docs/zh/cli/standalone.md +91 -0
- package/docs/zh/configuration.md +46 -7
- package/docs/zh/custom_domains.md +250 -0
- package/docs/zh/intlayer_with_tanstack+solid.md +15 -36
- package/docs/zh/intlayer_with_tanstack.md +25 -16
- package/docs/zh/intlayer_with_vanilla.md +506 -0
- package/package.json +8 -8
- package/src/doc.ts +4 -1
- package/src/generated/docs.entry.ts +60 -0
- package/docs/ar/bundle_optimization.md +0 -185
- package/docs/de/bundle_optimization.md +0 -195
- package/docs/en-GB/bundle_optimization.md +0 -184
- package/docs/es/bundle_optimization.md +0 -194
- package/docs/fr/bundle_optimization.md +0 -184
- package/docs/hi/bundle_optimization.md +0 -185
- package/docs/id/bundle_optimization.md +0 -185
- package/docs/it/bundle_optimization.md +0 -185
- package/docs/ja/bundle_optimization.md +0 -185
- package/docs/ko/bundle_optimization.md +0 -185
- package/docs/pl/bundle_optimization.md +0 -185
- package/docs/pt/bundle_optimization.md +0 -184
- package/docs/ru/bundle_optimization.md +0 -185
- package/docs/tr/bundle_optimization.md +0 -184
- package/docs/uk/bundle_optimization.md +0 -186
- package/docs/vi/bundle_optimization.md +0 -185
- package/docs/zh/bundle_optimization.md +0 -185
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
createdAt: 2025-11-25
|
|
3
|
-
updatedAt: 2025-11-25
|
|
4
|
-
title: Optimización del Tamaño y Rendimiento del Bundle i18n
|
|
5
|
-
description: Reduce el tamaño del bundle de la aplicación optimizando el contenido de internacionalización (i18n). Aprende a aprovechar tree shaking y lazy loading para diccionarios con Intlayer.
|
|
6
|
-
keywords:
|
|
7
|
-
- Optimización de Bundle
|
|
8
|
-
- Automatización de Contenido
|
|
9
|
-
- Contenido Dinámico
|
|
10
|
-
- Intlayer
|
|
11
|
-
- Next.js
|
|
12
|
-
- JavaScript
|
|
13
|
-
- React
|
|
14
|
-
slugs:
|
|
15
|
-
- doc
|
|
16
|
-
- concept
|
|
17
|
-
- bundle-optimization
|
|
18
|
-
history:
|
|
19
|
-
- version: 6.0.0
|
|
20
|
-
date: 2025-11-25
|
|
21
|
-
changes: "Historial inicial"
|
|
22
|
-
---
|
|
23
|
-
|
|
24
|
-
# Optimización del Tamaño y Rendimiento del Bundle i18n
|
|
25
|
-
|
|
26
|
-
Uno de los desafíos más comunes con las soluciones tradicionales de i18n que dependen de archivos JSON es gestionar el tamaño del contenido. Si los desarrolladores no separan manualmente el contenido en namespaces, los usuarios a menudo terminan descargando las traducciones de todas las páginas y potencialmente de todos los idiomas solo para ver una sola página.
|
|
27
|
-
|
|
28
|
-
Por ejemplo, una aplicación con 10 páginas traducidas a 10 idiomas podría hacer que un usuario descargue el contenido de 100 páginas, aunque solo necesite **una** (la página actual en el idioma actual). Esto conduce a un desperdicio de ancho de banda y tiempos de carga más lentos.
|
|
29
|
-
|
|
30
|
-
> Para detectarlo, puedes usar analizadores de bundle como `rollup-plugin-visualizer` (vite), `@next/bundle-analyzer` (next.js) o `webpack-bundle-analyzer` (React CRA / Angular / etc).
|
|
31
|
-
|
|
32
|
-
**Intlayer resuelve este problema mediante la optimización en tiempo de compilación.** Analiza tu código para detectar qué diccionarios se usan realmente por componente y reinserta solo el contenido necesario en tu bundle.
|
|
33
|
-
|
|
34
|
-
## Tabla de Contenidos
|
|
35
|
-
|
|
36
|
-
<TOC />
|
|
37
|
-
|
|
38
|
-
## Cómo Funciona
|
|
39
|
-
|
|
40
|
-
Intlayer utiliza un **enfoque por componente**. A diferencia de los archivos JSON globales, tu contenido se define junto a tus componentes o dentro de ellos. Durante el proceso de compilación, Intlayer:
|
|
41
|
-
|
|
42
|
-
1. **Analiza** tu código para encontrar llamadas a `useIntlayer`.
|
|
43
|
-
2. **Construye** el contenido del diccionario correspondiente.
|
|
44
|
-
3. **Reemplaza** la llamada a `useIntlayer` con código optimizado basado en tu configuración.
|
|
45
|
-
|
|
46
|
-
Esto garantiza que:
|
|
47
|
-
|
|
48
|
-
- Si un componente no se importa, su contenido no se incluye en el bundle (Eliminación de Código Muerto).
|
|
49
|
-
- Si un componente se carga de forma lazy, su contenido también se carga de forma lazy.
|
|
50
|
-
|
|
51
|
-
## Configuración por Plataforma
|
|
52
|
-
|
|
53
|
-
### Next.js
|
|
54
|
-
|
|
55
|
-
Next.js requiere el plugin `@intlayer/swc` para manejar la transformación, ya que Next.js utiliza SWC para las compilaciones.
|
|
56
|
-
|
|
57
|
-
> Este plugin está instalado por defecto porque los plugins SWC aún son experimentales para Next.js. Esto podría cambiar en el futuro.
|
|
58
|
-
|
|
59
|
-
### Vite
|
|
60
|
-
|
|
61
|
-
Vite utiliza el plugin `@intlayer/babel` que está incluido como dependencia de `vite-intlayer`. La optimización está habilitada por defecto.
|
|
62
|
-
|
|
63
|
-
### Webpack
|
|
64
|
-
|
|
65
|
-
Para habilitar la optimización del bundle con Intlayer en Webpack, necesitas instalar y configurar el plugin adecuado de Babel (`@intlayer/babel`) o SWC (`@intlayer/swc`).
|
|
66
|
-
|
|
67
|
-
### Expo / Lynx
|
|
68
|
-
|
|
69
|
-
La optimización del bundle **no está disponible aún** para esta plataforma. El soporte será añadido en una versión futura.
|
|
70
|
-
|
|
71
|
-
## Configuración
|
|
72
|
-
|
|
73
|
-
Puedes controlar cómo Intlayer optimiza tu bundle a través de la propiedad `build` en tu archivo `intlayer.config.ts`.
|
|
74
|
-
|
|
75
|
-
```typescript fileName="intlayer.config.ts"
|
|
76
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
77
|
-
|
|
78
|
-
const config: IntlayerConfig = {
|
|
79
|
-
internationalization: {
|
|
80
|
-
locales: [Locales.ENGLISH, Locales.FRENCH],
|
|
81
|
-
defaultLocale: Locales.ENGLISH,
|
|
82
|
-
},
|
|
83
|
-
dictionary: {},
|
|
84
|
-
build: {
|
|
85
|
-
optimize: true,
|
|
86
|
-
traversePattern: ["**/*.{js,ts,mjs,cjs,jsx,tsx}", "!**/node_modules/**"],
|
|
87
|
-
},
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
export default config;
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
> Se recomienda mantener la opción por defecto para `optimize` en la mayoría de los casos.
|
|
94
|
-
|
|
95
|
-
> Consulta la documentación de configuración para más detalles: [Configuración](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/configuration.md)
|
|
96
|
-
|
|
97
|
-
### Opciones de Build
|
|
98
|
-
|
|
99
|
-
Las siguientes opciones están disponibles bajo el objeto de configuración `build`:
|
|
100
|
-
|
|
101
|
-
| Propiedad | Tipo | Valor por defecto | Descripción |
|
|
102
|
-
| :-------------------- | :------------------------------- | :------------------------------ | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
103
|
-
| **`optimize`** | `boolean` | `undefined` | Controla si la optimización de la build está habilitada. Si es `true`, Intlayer reemplaza las llamadas al diccionario con inyecciones optimizadas. Si es `false`, la optimización está deshabilitada. Idealmente se debe establecer en `true` en producción. |
|
|
104
|
-
| **`importMode`** | `'static' , 'dynamic' , 'fetch'` | `'static'` | **Deprecated**: Use `dictionary.importMode` instead. Determina cómo se cargan los diccionarios (ver detalles a continuación). |
|
|
105
|
-
| **`traversePattern`** | `string[]` | `['**/*.{js,ts,jsx,tsx}', ...]` | Patrones glob que definen qué archivos Intlayer debe escanear para la optimización. Úsalo para excluir archivos no relacionados y acelerar las builds. |
|
|
106
|
-
| **`outputFormat`** | `'esm', 'cjs'` | `'esm', 'cjs'` | Controla el formato de salida de los diccionarios construidos. |
|
|
107
|
-
|
|
108
|
-
## Modos de Importación
|
|
109
|
-
|
|
110
|
-
La configuración `importMode` dicta cómo se inyecta el contenido del diccionario en tu componente.
|
|
111
|
-
|
|
112
|
-
### 1. Modo Estático (`default`)
|
|
113
|
-
|
|
114
|
-
En modo estático, Intlayer reemplaza `useIntlayer` por `useDictionary` e inyecta el diccionario directamente en el bundle de JavaScript.
|
|
115
|
-
|
|
116
|
-
- **Ventajas:** Renderizado instantáneo (síncrono), sin solicitudes de red adicionales durante la hidratación.
|
|
117
|
-
- **Desventajas:** El bundle incluye traducciones para **todos** los idiomas disponibles para ese componente específico.
|
|
118
|
-
- **Ideal para:** Aplicaciones de una sola página (SPA).
|
|
119
|
-
|
|
120
|
-
**Ejemplo de código transformado:**
|
|
121
|
-
|
|
122
|
-
```tsx
|
|
123
|
-
// Tu código
|
|
124
|
-
const content = useIntlayer("my-key");
|
|
125
|
-
|
|
126
|
-
// Código optimizado (Estático)
|
|
127
|
-
const content = useDictionary({
|
|
128
|
-
key: "my-key",
|
|
129
|
-
content: {
|
|
130
|
-
nodeType: "translation",
|
|
131
|
-
translation: {
|
|
132
|
-
en: "My title",
|
|
133
|
-
fr: "Mon titre",
|
|
134
|
-
},
|
|
135
|
-
},
|
|
136
|
-
});
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
### 2. Modo Dinámico
|
|
140
|
-
|
|
141
|
-
En modo dinámico, Intlayer reemplaza `useIntlayer` por `useDictionaryAsync`. Esto utiliza `import()` (mecanismo similar a Suspense) para cargar perezosamente específicamente el JSON para la localidad actual.
|
|
142
|
-
|
|
143
|
-
- **Ventajas:** **Eliminación de código a nivel de localidad.** Un usuario que vea la versión en inglés solo descargará el diccionario en inglés. El diccionario en francés nunca se carga.
|
|
144
|
-
- **Desventajas:** Genera una solicitud de red (descarga de recurso) por componente durante la hidratación.
|
|
145
|
-
- **Ideal para:** Bloques grandes de texto, artículos o aplicaciones que soportan muchos idiomas donde el tamaño del bundle es crítico.
|
|
146
|
-
|
|
147
|
-
**Ejemplo de código transformado:**
|
|
148
|
-
|
|
149
|
-
```tsx
|
|
150
|
-
// Tu código
|
|
151
|
-
const content = useIntlayer("my-key");
|
|
152
|
-
|
|
153
|
-
// Código optimizado (Dinámico)
|
|
154
|
-
const content = useDictionaryAsync({
|
|
155
|
-
en: () =>
|
|
156
|
-
import(".intlayer/dynamic_dictionary/my-key/en.json").then(
|
|
157
|
-
(mod) => mod.default
|
|
158
|
-
),
|
|
159
|
-
fr: () =>
|
|
160
|
-
import(".intlayer/dynamic_dictionary/my-key/fr.json").then(
|
|
161
|
-
(mod) => mod.default
|
|
162
|
-
),
|
|
163
|
-
});
|
|
164
|
-
```
|
|
165
|
-
|
|
166
|
-
> Al usar `importMode: 'dynamic'`, si tienes 100 componentes usando `useIntlayer` en una sola página, el navegador intentará realizar 100 solicitudes separadas. Para evitar esta "cascada" de peticiones, agrupa el contenido en menos archivos `.content` (por ejemplo, un diccionario por sección de página) en lugar de uno por componente átomo.
|
|
167
|
-
|
|
168
|
-
> Actualmente, `importMode: 'dynamic'` no está completamente soportado para Vue y Svelte. Se recomienda usar `importMode: 'static'` para estos frameworks hasta futuras actualizaciones.
|
|
169
|
-
|
|
170
|
-
### 3. Modo Live
|
|
171
|
-
|
|
172
|
-
Se comporta de manera similar al modo Dinámico, pero intenta obtener primero los diccionarios desde la API de Intlayer Live Sync. Si la llamada a la API falla o el contenido no está marcado para actualizaciones en vivo, vuelve a la importación dinámica.
|
|
173
|
-
|
|
174
|
-
> Consulta la documentación del CMS para más detalles: [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/intlayer_CMS.md)
|
|
175
|
-
|
|
176
|
-
## Resumen: Estático vs Dinámico
|
|
177
|
-
|
|
178
|
-
| Característica | Modo Estático | Modo Dinámico |
|
|
179
|
-
| :----------------------- | :-------------------------------------------------------- | :--------------------------------------- |
|
|
180
|
-
| **Tamaño del Bundle JS** | Más grande (incluye todos los idiomas para el componente) | Más pequeño (solo código, sin contenido) |
|
|
181
|
-
|
|
182
|
-
Se comporta de manera similar al modo Dinámico pero intenta obtener los diccionarios primero desde la API de Intlayer Live Sync. Si la llamada a la API falla o el contenido no está marcado para actualizaciones en vivo, vuelve a la importación dinámica.
|
|
183
|
-
|
|
184
|
-
> Consulte la documentación del CMS para más detalles: [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/intlayer_CMS.md)
|
|
185
|
-
|
|
186
|
-
## Resumen: Estático vs Dinámico
|
|
187
|
-
|
|
188
|
-
| Característica | Modo Estático | Modo Dinámico |
|
|
189
|
-
| :----------------------- | :-------------------------------------------------------- | :---------------------------------------- |
|
|
190
|
-
| **Tamaño del Bundle JS** | Más grande (incluye todos los idiomas para el componente) | Más pequeño (solo código, sin contenido) |
|
|
191
|
-
| **Carga Inicial** | Instantánea (El contenido está en el bundle) | Ligera demora (Obtiene JSON) |
|
|
192
|
-
| **Solicitudes de Red** | 0 solicitudes adicionales | 1 solicitud por diccionario |
|
|
193
|
-
| **Tree Shaking** | A nivel de componente | A nivel de componente + a nivel de idioma |
|
|
194
|
-
| **Mejor Caso de Uso** | Componentes UI, Aplicaciones pequeñas | Páginas con mucho texto, Muchos idiomas |
|
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
createdAt: 2025-11-25
|
|
3
|
-
updatedAt: 2025-11-25
|
|
4
|
-
title: Optimisation de la taille et des performances du bundle i18n
|
|
5
|
-
description: Réduisez la taille du bundle de votre application en optimisant le contenu d'internationalisation (i18n). Apprenez à exploiter le tree shaking et le lazy loading pour les dictionnaires avec Intlayer.
|
|
6
|
-
keywords:
|
|
7
|
-
- Optimisation du bundle
|
|
8
|
-
- Automatisation du contenu
|
|
9
|
-
- Contenu dynamique
|
|
10
|
-
- Intlayer
|
|
11
|
-
- Next.js
|
|
12
|
-
- JavaScript
|
|
13
|
-
- React
|
|
14
|
-
slugs:
|
|
15
|
-
- doc
|
|
16
|
-
- concept
|
|
17
|
-
- bundle-optimization
|
|
18
|
-
history:
|
|
19
|
-
- version: 6.0.0
|
|
20
|
-
date: 2025-11-25
|
|
21
|
-
changes: "Historique initial"
|
|
22
|
-
---
|
|
23
|
-
|
|
24
|
-
# Optimisation de la taille et des performances du bundle i18n
|
|
25
|
-
|
|
26
|
-
L'un des défis les plus courants avec les solutions i18n traditionnelles basées sur des fichiers JSON est la gestion de la taille du contenu. Si les développeurs ne séparent pas manuellement le contenu en namespaces, les utilisateurs finissent souvent par télécharger les traductions de chaque page et potentiellement de chaque langue simplement pour afficher une seule page.
|
|
27
|
-
|
|
28
|
-
Par exemple, une application avec 10 pages traduites en 10 langues peut entraîner le téléchargement par un utilisateur du contenu de 100 pages, alors qu'il n'a besoin que d'**une seule** (la page actuelle dans la langue actuelle). Cela conduit à un gaspillage de bande passante et à des temps de chargement plus lents.
|
|
29
|
-
|
|
30
|
-
> Pour le détecter, vous pouvez utiliser un analyseur de bundle comme `rollup-plugin-visualizer` (vite), `@next/bundle-analyzer` (next.js), ou `webpack-bundle-analyzer` (React CRA / Angular / etc).
|
|
31
|
-
|
|
32
|
-
**Intlayer résout ce problème grâce à une optimisation au moment de la compilation.** Il analyse votre code pour détecter quels dictionnaires sont réellement utilisés par composant et réinjecte uniquement le contenu nécessaire dans votre bundle.
|
|
33
|
-
|
|
34
|
-
## Table des matières
|
|
35
|
-
|
|
36
|
-
<TOC />
|
|
37
|
-
|
|
38
|
-
## Comment ça fonctionne
|
|
39
|
-
|
|
40
|
-
Intlayer utilise une **approche par composant**. Contrairement aux fichiers JSON globaux, votre contenu est défini à côté ou à l'intérieur de vos composants. Lors du processus de build, Intlayer :
|
|
41
|
-
|
|
42
|
-
1. **Analyse** votre code pour trouver les appels à `useIntlayer`.
|
|
43
|
-
2. **Construit** le contenu du dictionnaire correspondant.
|
|
44
|
-
3. **Remplace** l'appel à `useIntlayer` par un code optimisé basé sur votre configuration.
|
|
45
|
-
|
|
46
|
-
Cela garantit que :
|
|
47
|
-
|
|
48
|
-
- Si un composant n'est pas importé, son contenu n'est pas inclus dans le bundle (élimination de code mort).
|
|
49
|
-
- Si un composant est chargé de manière lazy, son contenu est également chargé de manière lazy.
|
|
50
|
-
|
|
51
|
-
## Configuration par plateforme
|
|
52
|
-
|
|
53
|
-
### Next.js
|
|
54
|
-
|
|
55
|
-
Next.js nécessite le plugin `@intlayer/swc` pour gérer la transformation, car Next.js utilise SWC pour les builds.
|
|
56
|
-
|
|
57
|
-
> Ce plugin est installé par défaut car les plugins SWC sont encore expérimentaux pour Next.js. Cela pourrait changer à l'avenir.
|
|
58
|
-
|
|
59
|
-
### Vite
|
|
60
|
-
|
|
61
|
-
Vite utilise le plugin `@intlayer/babel` qui est inclus en tant que dépendance de `vite-intlayer`. L'optimisation est activée par défaut.
|
|
62
|
-
|
|
63
|
-
### Webpack
|
|
64
|
-
|
|
65
|
-
Pour activer l'optimisation du bundle avec Intlayer sur Webpack, vous devez installer et configurer le plugin Babel (`@intlayer/babel`) ou SWC (`@intlayer/swc`) approprié.
|
|
66
|
-
|
|
67
|
-
### Expo / Lynx
|
|
68
|
-
|
|
69
|
-
L'optimisation du bundle n'est **pas encore disponible** pour cette plateforme. Le support sera ajouté dans une future version.
|
|
70
|
-
|
|
71
|
-
## Configuration
|
|
72
|
-
|
|
73
|
-
Vous pouvez contrôler la manière dont Intlayer optimise votre bundle via la propriété `build` dans votre fichier `intlayer.config.ts`.
|
|
74
|
-
|
|
75
|
-
```typescript fileName="intlayer.config.ts"
|
|
76
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
77
|
-
|
|
78
|
-
const config: IntlayerConfig = {
|
|
79
|
-
internationalization: {
|
|
80
|
-
locales: [Locales.ENGLISH, Locales.FRENCH],
|
|
81
|
-
defaultLocale: Locales.ENGLISH,
|
|
82
|
-
},
|
|
83
|
-
dictionary: {},
|
|
84
|
-
build: {
|
|
85
|
-
optimize: true,
|
|
86
|
-
traversePattern: ["**/*.{js,ts,mjs,cjs,jsx,tsx}", "!**/node_modules/**"],
|
|
87
|
-
},
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
export default config;
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
> Il est recommandé de conserver l'option par défaut pour `optimize` dans la grande majorité des cas.
|
|
94
|
-
|
|
95
|
-
> Voir la documentation de configuration pour plus de détails : [Configuration](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/configuration.md)
|
|
96
|
-
|
|
97
|
-
### Options de build
|
|
98
|
-
|
|
99
|
-
Les options suivantes sont disponibles sous l'objet de configuration `build` :
|
|
100
|
-
|
|
101
|
-
| Propriété | Type | Par défaut | Description |
|
|
102
|
-
| :-------------------- | :------------------------------- | :------------------------------ | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
103
|
-
| **`optimize`** | `boolean` | `undefined` | Contrôle si l'optimisation de la build est activée. Si `true`, Intlayer remplace les appels au dictionnaire par des injections optimisées. Si `false`, l'optimisation est désactivée. Idéalement configuré à `true` en production. |
|
|
104
|
-
| **`importMode`** | `'static' , 'dynamic' , 'fetch'` | `'static'` | **Deprecated**: Use `dictionary.importMode` instead. Détermine comment les dictionnaires sont chargés (voir détails ci-dessous). |
|
|
105
|
-
| **`traversePattern`** | `string[]` | `['**/*.{js,ts,jsx,tsx}', ...]` | Modèles globaux définissant les fichiers que Intlayer doit analyser pour l'optimisation. Utilisez ceci pour exclure les fichiers non pertinents et accélérer les builds. |
|
|
106
|
-
| **`outputFormat`** | `'esm', 'cjs'` | `'esm', 'cjs'` | Contrôle le format de sortie des dictionnaires construits. |
|
|
107
|
-
|
|
108
|
-
## Modes d'importation
|
|
109
|
-
|
|
110
|
-
Le paramètre `importMode` détermine comment le contenu du dictionnaire est injecté dans votre composant.
|
|
111
|
-
|
|
112
|
-
### 1. Mode statique (`default`)
|
|
113
|
-
|
|
114
|
-
En mode statique, Intlayer remplace `useIntlayer` par `useDictionary` et injecte le dictionnaire directement dans le bundle JavaScript.
|
|
115
|
-
|
|
116
|
-
- **Avantages :** Rendu instantané (synchrone), aucune requête réseau supplémentaire lors de l'hydratation.
|
|
117
|
-
- **Inconvénients :** Le bundle inclut les traductions pour **toutes** les langues disponibles pour ce composant spécifique.
|
|
118
|
-
- **Idéal pour :** Applications monopage (SPA).
|
|
119
|
-
|
|
120
|
-
**Exemple de code transformé :**
|
|
121
|
-
|
|
122
|
-
```tsx
|
|
123
|
-
// Votre code
|
|
124
|
-
const content = useIntlayer("my-key");
|
|
125
|
-
|
|
126
|
-
// Code optimisé (Statique)
|
|
127
|
-
const content = useDictionary({
|
|
128
|
-
key: "my-key",
|
|
129
|
-
content: {
|
|
130
|
-
nodeType: "translation",
|
|
131
|
-
translation: {
|
|
132
|
-
en: "My title",
|
|
133
|
-
fr: "Mon titre",
|
|
134
|
-
},
|
|
135
|
-
},
|
|
136
|
-
});
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
### 2. Mode Dynamique
|
|
140
|
-
|
|
141
|
-
En mode dynamique, Intlayer remplace `useIntlayer` par `useDictionaryAsync`. Cela utilise `import()` (mécanisme similaire à Suspense) pour charger paresseusement le JSON spécifique à la locale courante.
|
|
142
|
-
|
|
143
|
-
- **Avantages :** **Élimination des modules inutilisés au niveau de la locale.** Un utilisateur visualisant la version anglaise téléchargera _uniquement_ le dictionnaire anglais. Le dictionnaire français n'est jamais chargé.
|
|
144
|
-
- **Inconvénients :** Déclenche une requête réseau (récupération d'asset) par composant lors de l'hydratation.
|
|
145
|
-
- **Idéal pour :** Blocs de texte volumineux, articles, ou applications supportant de nombreuses langues où la taille du bundle est critique.
|
|
146
|
-
|
|
147
|
-
**Exemple de code transformé :**
|
|
148
|
-
|
|
149
|
-
```tsx
|
|
150
|
-
// Votre code
|
|
151
|
-
const content = useIntlayer("my-key");
|
|
152
|
-
|
|
153
|
-
// Code optimisé (Dynamique)
|
|
154
|
-
const content = useDictionaryAsync({
|
|
155
|
-
en: () =>
|
|
156
|
-
import(".intlayer/dynamic_dictionary/my-key/en.json").then(
|
|
157
|
-
(mod) => mod.default
|
|
158
|
-
),
|
|
159
|
-
fr: () =>
|
|
160
|
-
import(".intlayer/dynamic_dictionary/my-key/fr.json").then(
|
|
161
|
-
(mod) => mod.default
|
|
162
|
-
),
|
|
163
|
-
});
|
|
164
|
-
```
|
|
165
|
-
|
|
166
|
-
> Lors de l'utilisation de `importMode: 'dynamic'`, si vous avez 100 composants utilisant `useIntlayer` sur une seule page, le navigateur tentera 100 requêtes distinctes. Pour éviter cette "cascade" de requêtes, regroupez le contenu dans moins de fichiers `.content` (par exemple, un dictionnaire par section de page) plutôt qu'un par composant atomique.
|
|
167
|
-
|
|
168
|
-
> Actuellement, `importMode: 'dynamic'` n'est pas entièrement pris en charge pour Vue et Svelte. Il est recommandé d'utiliser `importMode: 'static'` pour ces frameworks en attendant des mises à jour ultérieures.
|
|
169
|
-
|
|
170
|
-
### 3. Mode Live
|
|
171
|
-
|
|
172
|
-
Se comporte de manière similaire au mode Dynamique mais tente d'abord de récupérer les dictionnaires via l'API Intlayer Live Sync. Si l'appel API échoue ou si le contenu n'est pas marqué pour des mises à jour en direct, il revient à l'import dynamique.
|
|
173
|
-
|
|
174
|
-
> Voir la documentation CMS pour plus de détails : [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/intlayer_CMS.md)
|
|
175
|
-
|
|
176
|
-
## Résumé : Statique vs Dynamique
|
|
177
|
-
|
|
178
|
-
| Fonctionnalité | Mode Statique | Mode Dynamique |
|
|
179
|
-
| :---------------------- | :-------------------------------------------------------- | :---------------------------------------------- |
|
|
180
|
-
| **Taille du bundle JS** | Plus grande (inclut toutes les langues pour le composant) | Plus petite (seulement le code, pas le contenu) |
|
|
181
|
-
| **Chargement initial** | Instantané (Le contenu est dans le bundle) | Légère attente (Récupère du JSON) |
|
|
182
|
-
| **Requêtes réseau** | 0 requêtes supplémentaires | 1 requête par dictionnaire |
|
|
183
|
-
| **Tree Shaking** | Niveau composant | Niveau composant + niveau langue |
|
|
184
|
-
| **Cas d'utilisation** | Composants UI, petites applications | Pages avec beaucoup de texte, plusieurs langues |
|
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
createdAt: 2025-11-25
|
|
3
|
-
updatedAt: 2025-11-25
|
|
4
|
-
title: i18n बंडल आकार और प्रदर्शन का अनुकूलन
|
|
5
|
-
description: अंतर्राष्ट्रीयकरण (i18n) सामग्री को अनुकूलित करके एप्लिकेशन बंडल आकार को कम करें। Intlayer के साथ शब्दकोशों के लिए ट्री शेकिंग और लेज़ी लोडिंग का लाभ उठाना सीखें।
|
|
6
|
-
keywords:
|
|
7
|
-
- बंडल अनुकूलन
|
|
8
|
-
- सामग्री स्वचालन
|
|
9
|
-
- गतिशील सामग्री
|
|
10
|
-
- Intlayer
|
|
11
|
-
- Next.js
|
|
12
|
-
- JavaScript
|
|
13
|
-
- React
|
|
14
|
-
slugs:
|
|
15
|
-
- doc
|
|
16
|
-
- concept
|
|
17
|
-
- bundle-optimization
|
|
18
|
-
history:
|
|
19
|
-
- version: 6.0.0
|
|
20
|
-
date: 2025-11-25
|
|
21
|
-
changes: "Init history"
|
|
22
|
-
---
|
|
23
|
-
|
|
24
|
-
# i18n बंडल आकार और प्रदर्शन का अनुकूलन
|
|
25
|
-
|
|
26
|
-
JSON फ़ाइलों पर निर्भर पारंपरिक i18n समाधानों के साथ सबसे आम चुनौतियों में से एक सामग्री के आकार का प्रबंधन है। यदि डेवलपर्स सामग्री को मैन्युअल रूप से namespaces में विभाजित नहीं करते हैं, तो उपयोगकर्ता अक्सर केवल एक पृष्ठ देखने के लिए हर पृष्ठ और संभावित रूप से हर भाषा के अनुवाद डाउनलोड कर लेते हैं।
|
|
27
|
-
|
|
28
|
-
उदाहरण के लिए, 10 पृष्ठों वाले एक एप्लिकेशन के 10 भाषाओं में अनुवादित होने पर उपयोगकर्ता 100 पृष्ठों की सामग्री डाउनलोड कर सकता है, जबकि उसे केवल **एक** (वर्तमान पृष्ठ वर्तमान भाषा में) की आवश्यकता होती है। इससे बैंडविड्थ की बर्बादी होती है और लोड समय धीमा हो जाता है।
|
|
29
|
-
|
|
30
|
-
> इसे पता लगाने के लिए, आप `rollup-plugin-visualizer` (vite), `@next/bundle-analyzer` (next.js), या `webpack-bundle-analyzer` (React CRA / Angular / आदि) जैसे बंडल विश्लेषक का उपयोग कर सकते हैं।
|
|
31
|
-
|
|
32
|
-
**Intlayer इस समस्या को build-time optimization के माध्यम से हल करता है।** यह आपके कोड का विश्लेषण करता है ताकि पता लगाया जा सके कि कौन से डिक्शनरी वास्तव में प्रत्येक कंपोनेंट में उपयोग किए जाते हैं और केवल आवश्यक सामग्री को आपके बंडल में पुनः सम्मिलित करता है।
|
|
33
|
-
|
|
34
|
-
## विषय सूची
|
|
35
|
-
|
|
36
|
-
<TOC />
|
|
37
|
-
|
|
38
|
-
## यह कैसे काम करता है
|
|
39
|
-
|
|
40
|
-
Intlayer एक **प्रति-कंपोनेंट दृष्टिकोण** का उपयोग करता है। वैश्विक JSON फ़ाइलों के विपरीत, आपकी सामग्री आपके कंपोनेंट्स के साथ या उनके भीतर परिभाषित होती है। बिल्ड प्रक्रिया के दौरान, Intlayer:
|
|
41
|
-
|
|
42
|
-
1. आपके कोड का **विश्लेषण** करता है ताकि `useIntlayer` कॉल्स को खोज सके।
|
|
43
|
-
2. संबंधित डिक्शनरी सामग्री का **निर्माण** करता है।
|
|
44
|
-
3. आपकी कॉन्फ़िगरेशन के आधार पर `useIntlayer` कॉल को अनुकूलित कोड से **प्रतिस्थापित** करता है।
|
|
45
|
-
|
|
46
|
-
यह सुनिश्चित करता है कि:
|
|
47
|
-
|
|
48
|
-
- यदि कोई कंपोनेंट आयातित नहीं है, तो उसकी सामग्री बंडल में शामिल नहीं की जाती (Dead Code Elimination)।
|
|
49
|
-
- यदि कोई कंपोनेंट lazy-loaded है, तो उसकी सामग्री भी lazy-loaded होती है।
|
|
50
|
-
|
|
51
|
-
## प्लेटफ़ॉर्म द्वारा सेटअप
|
|
52
|
-
|
|
53
|
-
### Next.js
|
|
54
|
-
|
|
55
|
-
Next.js को ट्रांसफ़ॉर्मेशन को संभालने के लिए `@intlayer/swc` प्लगइन की आवश्यकता होती है, क्योंकि Next.js बिल्ड के लिए SWC का उपयोग करता है।
|
|
56
|
-
|
|
57
|
-
> यह प्लगइन डिफ़ॉल्ट रूप से इंस्टॉल होता है क्योंकि SWC प्लगइन्स अभी भी Next.js के लिए प्रायोगिक हैं। भविष्य में इसमें बदलाव हो सकता है।
|
|
58
|
-
|
|
59
|
-
### Vite
|
|
60
|
-
|
|
61
|
-
Vite `@intlayer/babel` प्लगइन का उपयोग करता है जो `vite-intlayer` की निर्भरता के रूप में शामिल है। अनुकूलन डिफ़ॉल्ट रूप से सक्षम है।
|
|
62
|
-
|
|
63
|
-
### Webpack
|
|
64
|
-
|
|
65
|
-
Webpack पर Intlayer के साथ बंडल अनुकूलन सक्षम करने के लिए, आपको उपयुक्त Babel (`@intlayer/babel`) या SWC (`@intlayer/swc`) प्लगइन को इंस्टॉल और कॉन्फ़िगर करना होगा।
|
|
66
|
-
|
|
67
|
-
### Expo / Lynx
|
|
68
|
-
|
|
69
|
-
इस प्लेटफ़ॉर्म के लिए बंडल अनुकूलन **अभी उपलब्ध नहीं है**। समर्थन भविष्य के रिलीज़ में जोड़ा जाएगा।
|
|
70
|
-
|
|
71
|
-
## कॉन्फ़िगरेशन
|
|
72
|
-
|
|
73
|
-
आप अपने `intlayer.config.ts` में `build` प्रॉपर्टी के माध्यम से नियंत्रित कर सकते हैं कि Intlayer आपके बंडल को कैसे अनुकूलित करता है।
|
|
74
|
-
|
|
75
|
-
```typescript fileName="intlayer.config.ts"
|
|
76
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
77
|
-
|
|
78
|
-
const config: IntlayerConfig = {
|
|
79
|
-
internationalization: {
|
|
80
|
-
locales: [Locales.ENGLISH, Locales.FRENCH],
|
|
81
|
-
defaultLocale: Locales.ENGLISH,
|
|
82
|
-
},
|
|
83
|
-
dictionary: {},
|
|
84
|
-
build: {
|
|
85
|
-
optimize: true,
|
|
86
|
-
importMode: "static", // या 'dynamic'
|
|
87
|
-
traversePattern: ["**/*.{js,ts,mjs,cjs,jsx,tsx}", "!**/node_modules/**"],
|
|
88
|
-
},
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
export default config;
|
|
92
|
-
```
|
|
93
|
-
|
|
94
|
-
> अधिकांश मामलों में `optimize` के लिए डिफ़ॉल्ट विकल्प रखना अनुशंसित है।
|
|
95
|
-
|
|
96
|
-
> अधिक विवरण के लिए डॉक्यूमेंटेशन कॉन्फ़िगरेशन देखें: [Configuration](https://github.com/aymericzip/intlayer/blob/main/docs/docs/hi/configuration.md)
|
|
97
|
-
|
|
98
|
-
### बिल्ड विकल्प
|
|
99
|
-
|
|
100
|
-
`build` कॉन्फ़िगरेशन ऑब्जेक्ट के तहत निम्नलिखित विकल्प उपलब्ध हैं:
|
|
101
|
-
|
|
102
|
-
| प्रॉपर्टी | प्रकार | डिफ़ॉल्ट | विवरण |
|
|
103
|
-
| :-------------------- | :------------------------------- | :------------------------------ | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
104
|
-
| **`optimize`** | `boolean` | `undefined` | नियंत्रित करता है कि बिल्ड ऑप्टिमाइज़ेशन सक्षम है या नहीं। यदि `true` है, то Intlayer डिक्शनरी कॉल्स को ऑप्टिमाइज़्ड इंजेक्ट्स से बदल देता है। यदि `false` है, तो ऑप्टिमाइज़ेशन अक्षम होता है। आदर्श रूप से उत्पादन में इसे `true` पर सेट किया जाना चाहिए। |
|
|
105
|
-
| **`importMode`** | `'static' , 'dynamic' , 'fetch'` | `'static'` | **Deprecated**: Use `dictionary.importMode` instead. यह निर्धारित करता है कि डिक्शनरी कैसे लोड की जाती हैं (नीце विवरण देखें)। |
|
|
106
|
-
| **`traversePattern`** | `string[]` | `['**/*.{js,ts,jsx,tsx}', ...]` | ग्लोब पैटर्न जो परिभाषित करते हैं कि Intlayer किन फाइलों को ऑप्टिमाइज़ेशन के लिए स्कैन करेगा। इसका उपयोग अप्रासंगिक फाइलों को बाहर करने और बिल्ड को तेज़ करने के लिए करें। |
|
|
107
|
-
| **`outputFormat`** | `'esm', 'cjs'` | `'esm', 'cjs'` | निर्मित डिक्शनरी के आउटपुट फॉर्मेट को नियंत्रित करता है। |
|
|
108
|
-
|
|
109
|
-
## इम्पोर्ट मोड्स
|
|
110
|
-
|
|
111
|
-
`importMode` सेटिंग यह निर्धारित करती है कि डिक्शनरी सामग्री आपके कंपोनेंट में कैसे इंजेक्ट की जाती है।
|
|
112
|
-
|
|
113
|
-
### 1. स्टैटिक मोड (`default`)
|
|
114
|
-
|
|
115
|
-
स्थैतिक मोड में, Intlayer `useIntlayer` को `useDictionary` से बदल देता है और डिक्शनरी को सीधे JavaScript बंडल में इंजेक्ट करता है।
|
|
116
|
-
|
|
117
|
-
- **फायदे:** त्वरित रेंडरिंग (सिंक्रोनस), हाइड्रेशन के दौरान कोई अतिरिक्त नेटवर्क अनुरोध नहीं।
|
|
118
|
-
- **नुकसान:** बंडल में उस विशिष्ट कंपोनेंट के लिए **सभी** उपलब्ध भाषाओं के अनुवाद शामिल होते हैं।
|
|
119
|
-
- **सबसे अच्छा:** सिंगल पेज एप्लिकेशन (SPA) के लिए।
|
|
120
|
-
|
|
121
|
-
**परिवर्तित कोड उदाहरण:**
|
|
122
|
-
|
|
123
|
-
```tsx
|
|
124
|
-
// आपका कोड
|
|
125
|
-
const content = useIntlayer("my-key");
|
|
126
|
-
|
|
127
|
-
// ऑप्टिमाइज़्ड कोड (स्थैतिक)
|
|
128
|
-
const content = useDictionary({
|
|
129
|
-
key: "my-key",
|
|
130
|
-
content: {
|
|
131
|
-
nodeType: "translation",
|
|
132
|
-
translation: {
|
|
133
|
-
en: "My title",
|
|
134
|
-
fr: "Mon titre",
|
|
135
|
-
},
|
|
136
|
-
},
|
|
137
|
-
});
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
### 2. डायनेमिक मोड
|
|
141
|
-
|
|
142
|
-
डायनामिक मोड में, Intlayer `useIntlayer` को `useDictionaryAsync` से बदल देता है। यह `import()` (Suspense-जैसे तंत्र) का उपयोग करता है ताकि वर्तमान लोकल के लिए JSON को लेज़ी-लोड किया जा सके।
|
|
143
|
-
|
|
144
|
-
- **फायदे:** **लोकल-स्तर पर ट्री शेकिंग।** अंग्रेज़ी संस्करण देखने वाला उपयोगकर्ता केवल अंग्रेज़ी डिक्शनरी डाउनलोड करेगा। फ्रेंच डिक्शनरी कभी लोड नहीं होती।
|
|
145
|
-
- **नुकसान:** हाइड्रेशन के दौरान प्रत्येक कंपोनेंट के लिए एक नेटवर्क अनुरोध (एसेट फेच) ट्रिगर होता है।
|
|
146
|
-
- **सबसे अच्छा:** बड़े टेक्स्ट ब्लॉक्स, लेख, या कई भाषाओं का समर्थन करने वाले एप्लिकेशन जहां बंडल का आकार महत्वपूर्ण हो।
|
|
147
|
-
|
|
148
|
-
**परिवर्तित कोड उदाहरण:**
|
|
149
|
-
|
|
150
|
-
```tsx
|
|
151
|
-
// आपका कोड
|
|
152
|
-
const content = useIntlayer("my-key");
|
|
153
|
-
|
|
154
|
-
// अनुकूलित कोड (डायनामिक)
|
|
155
|
-
const content = useDictionaryAsync({
|
|
156
|
-
en: () =>
|
|
157
|
-
import(".intlayer/dynamic_dictionary/my-key/en.json").then(
|
|
158
|
-
(mod) => mod.default
|
|
159
|
-
),
|
|
160
|
-
fr: () =>
|
|
161
|
-
import(".intlayer/dynamic_dictionary/my-key/fr.json").then(
|
|
162
|
-
(mod) => mod.default
|
|
163
|
-
),
|
|
164
|
-
});
|
|
165
|
-
```
|
|
166
|
-
|
|
167
|
-
> जब `importMode: 'dynamic'` का उपयोग किया जाता है, यदि आपके पास एक पेज पर 100 कंपोनेंट्स हैं जो `useIntlayer` का उपयोग करते हैं, तो ब्राउज़र 100 अलग-अलग फेच करने का प्रयास करेगा। इस "वाटरफॉल" अनुरोधों से बचने के लिए, सामग्री को कम `.content` फाइलों में समूहित करें (जैसे, पेज सेक्शन के लिए एक डिक्शनरी) बजाय कि प्रत्येक एटम कंपोनेंट के लिए एक।
|
|
168
|
-
|
|
169
|
-
> वर्तमान में, `importMode: 'dynamic'` Vue और Svelte के लिए पूरी तरह से समर्थित नहीं है। इन फ्रेमवर्क्स के लिए आगे के अपडेट तक `importMode: 'static'` का उपयोग करने की सलाह दी जाती है।
|
|
170
|
-
|
|
171
|
-
### 3. लाइव मोड
|
|
172
|
-
|
|
173
|
-
डायनामिक मोड के समान व्यवहार करता है लेकिन पहले Intlayer लाइव सिंक API से शब्दकोश प्राप्त करने का प्रयास करता है। यदि API कॉल विफल हो जाती है या सामग्री लाइव अपडेट के लिए चिह्नित नहीं है, तो यह डायनामिक इम्पोर्ट पर वापस चला जाता है।
|
|
174
|
-
|
|
175
|
-
> अधिक जानकारी के लिए CMS दस्तावेज़ देखें: [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/hi/intlayer_CMS.md)
|
|
176
|
-
|
|
177
|
-
## सारांश: स्टैटिक बनाम डायनामिक
|
|
178
|
-
|
|
179
|
-
| फीचर | स्टैटिक मोड | डायनामिक मोड |
|
|
180
|
-
| :------------------------ | :------------------------------------------------- | :------------------------------------- |
|
|
181
|
-
| **JS बंडल आकार** | बड़ा (कंपोनेंट के लिए सभी भाषाओं को शामिल करता है) | सबसे छोटा (केवल कोड, कोई सामग्री नहीं) |
|
|
182
|
-
| **प्रारंभिक लोड** | त्वरित (सामग्री बंडल में है) | थोड़ा विलंब (JSON प्राप्त करता है) |
|
|
183
|
-
| **नेटवर्क अनुरोध** | 0 अतिरिक्त अनुरोध | प्रति शब्दकोश 1 अनुरोध |
|
|
184
|
-
| **ट्री शेकिंग** | कंपोनेंट-स्तर | कंपोनेंट-स्तर + लोकल-स्तर |
|
|
185
|
-
| **सर्वोत्तम उपयोग मामला** | UI कंपोनेंट्स, छोटे ऐप्स | बहुत सारे टेक्स्ट वाले पेज, कई भाषाएँ |
|