Comments (2)
C SSR проблем с частичной загрузкой не будет т.к. есть моментальный доступ к файловой системе и можно принимать решения в зависимости от обстоятельств запроса и наличия перевода для требуемого языка.
Как быть на фронте:
- Когда необходимо будет загрузить переводы для нескольких компонентов (это несколько запросов за переводами)?
- Отравлять ещё один запрос за переводом по умолчанию в случае если нет перевода компонента для требуемого языка?
Думаю тут нужен серверный обработчик таких запросов, у которого будет доступ к файловой системе и набор правил обработки ситуаций с отсутствием требуемого языка и возможностью склейки всех переводов в один ответ
from i18n.
Отравлять ещё один запрос за переводом по умолчанию в случае если нет перевода компонента для требуемого языка?
Перевод по умолчанию (base) всегда есть в коде компонента, так как с помощью него объявляются типы (через вызов i18n(componentName, baseTranslation)
).
Когда необходимо будет загрузить переводы для нескольких компонентов (это несколько запросов за переводами)?
Нужно собирать имена всех компонентов, которые надо рендерить на странице и только потом отправлять запрос
Думаю тут нужен серверный обработчик таких запросов, у которого будет доступ к файловой системе и набор правил обработки ситуаций с отсутствием требуемого языка и возможностью склейки всех переводов в один ответ
Можно сделать гораздо проще — на этапе сборке объединять переводы в большие JSON-файлы.
Например, разработчик может называть свои компоненты как main/header
, main/home
, settings/user
. А потом на этапе сборке объединять все main/*
и settings/*
. Соответственно в get()
можно посылать запрос по префиксу в имени компонента.
Учти только, что при выполнении get ('ru', ['main/home'])
функция может вернуть переводы не только для main/home
, но и для main/header
который сейчас может быть не нужен (или же был запрошен отдельный запросом). К этому надо быть готовым (хотя 2 запроса не страшно, если они идут редко).
from i18n.
Related Issues (15)
- Translation preprocessor
- number, time and count functions type mismatch HOT 6
- Add HMR support HOT 1
- is there a nice way to use nanostores/i18n outside of react / react-hooks? HOT 27
- SSR Example HOT 4
- does nanostores/i18n process process lists in international way? HOT 1
- runtime error when NODE_ENV === 'production', HOT 6
- Prevent `baseTranslation` from flashing HOT 9
- Error while using useStore HOT 4
- Usage in sandboxes HOT 2
- Nesting of translations HOT 3
- Generate types for `params()` automatically by TS string parsing
- Not able to change language HOT 5
- Clears data from local storage after page refresh HOT 8
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from i18n.