Большие локальные БД в React-native (Expo) - PullRequest
0 голосов
/ 07 мая 2018

Я нашел эту хорошую и простую статью https://medium.com/@jamuhl/translate-your-expo-io-react-native-mobile-application-aa220b2362d2 для реализации локализации в RN (в Expo).

Мой вариант использования немного отличается: в моем приложении есть список из сотен терминов для перевода (объект js ~ 1 МБ на каждый язык, раз 6-7 языков).

Приложение полностью автономно (нет возможности загрузить файлы локали с сервера), поэтому я ищу лучший способ ленивой загрузки нужного мне языка локали json / js.

Я здесь, чтобы посоветоваться с экспертами RN / i18next, возможно.

EDIT: Я в значительной степени скопировал конфигурацию i18n этой https://github.com/i18next/react-i18next/blob/master/example/react-native-expo/js/i18n.js

Реальные базы данных находятся в поле data:DB. Конечно, это не лучший способ загрузки тяжелых файлов, я всегда загружаю все БД всех языков. Могу ли я сохранить такую ​​же простую структуру, но лениво загружать только нужный мне язык? Иначе, есть пример local lazy-load (из файловой системы устройства) в i18next и response-native?

import i18n from 'i18next';
import {reactI18nextModule} from 'react-i18next';
i18n
    .use(languageDetector)
    .use(reactI18nextModule)
    .init({
        fallbackLng: 'en',
        resources: {
            en: {
                home: {
                    title: 'Welcome',
                    introduction: 'This text comes from i18next and is provided in english.',
                },
                data: { DB:require("./locales/it.json") },
            },
            de: {
                home: {
                    title: 'Willkommen',
                    introduction: 'Dieser Text ist von i18next und ist in deutsch.',
                },
                data: { DB:require("./locales/de.json") },

            }
        },
        // have a common namespace used around the full app
        ns: ['common'],
        defaultNS: 'home',

        debug: true,
        interpolation: {
            escapeValue: false, // not needed for react as it does escape per default to prevent xss!
        }
    });

1 Ответ

0 голосов
/ 07 мая 2018

С i18next довольно просто создать собственную реализацию бэкэнда ... https://www.i18next.com/misc/creating-own-plugins#backend

Я бы предложил объединить ваши переводы с приложением, а не загружать их с какого-либо внешнего ресурса. Вы также можете напрямую добавлять переводы на лету, используя https://www.i18next.com/overview/api#resource-handling

...