i18next の実装に成功しました。これはすばらしいライブラリです。私はまだ「ベストプラクティス」を探していますが。これは私が現在持っているセットアップで、一般的に気に入っています。
var userLanguage = 'en'; // set at runtime
i18n.init({
lng : userLanguage,
shortcutFunction : 'defaultValue',
fallbackLng : false,
load : 'unspecific',
resGetPath : 'locales/__lng__/__ns__.json'
});
DOM では、次のようなことを行います。
<span data-i18n="demo.myFirstExample">My first example</span>
そしてJSでは、次のようなことをします:
return i18n.t('demo.mySecondExample', 'My second example');
これは、コード自体の中で英語の翻訳を維持することを意味します。translation.json
ただし、i18next-parser を使用して、別のファイルを使用して他の言語を維持しています。
gulp.task('i18next', function()
{
gulp.src('app/**')
.pipe(i18next({
locales : ['nl','de'],
output : '../locales'
}))
.pipe(gulp.dest('locales'));
});
それはすべてうまくいきます。唯一の問題は、 に設定'en'
したときに、翻訳が含まれていないにもかかわらず、ファイルを取得することuserLanguage
を主張することです。404 を防ぐために、現在、そのファイルで空の json オブジェクトを提供しています。i18next
/locales/en/translation.json
{}
空の .json ファイルをまったく読み込まないようにする方法はありますか?