【问题标题】:Creating multi language web app with i18n-2 in express在 express 中使用 i18n-2 创建多语言 Web 应用程序
【发布时间】:2015-07-21 04:27:17
【问题描述】:

我使用i18n-2 module 创建了一个具有两种语言的 express(node.js) 网站,现在我遇到了问题。我在想,如果我更改默认语言以外的新语言,我网站中的所有链接都会自动带有/?lang 参数! i18n-2 会做还是我自己必须编写此功能?

现在,如果我手动添加/?lang=de,它可以工作,但如果我回到我的网站根目录,它会转到默认语言环境,并且该参数会从 url 中删除。

这是我的配置:

I18n.expressBind(app, {
   locales: ['en', 'de'],
   defaultLocale: 'en',
   cookieName: 'locale',
   extension: ".json"
});

app.use(function(req, res, next) {
   req.i18n.setLocaleFromQuery();
   req.i18n.setLocaleFromCookie();

   next();
 });

【问题讨论】:

  • 同样的问题,还没找到答案

标签: javascript node.js express internationalization i18next


【解决方案1】:

为了使所选语言永久存在,您需要安装一个名为 cookie-parser 的软件包:

npm install --save cookie-parser

然后将其附加到 Express 应用程序,如下所示:

var app = require('express')(),
    cookieParser = require('coookie-parser'),
    i18n2 = require('i18n-2');

app.use(cookieParser());
i18n2.expressBind(app, {
   locales: ['en', 'de'],
   defaultLocale: 'en',
   cookieName: 'locale'
});
app.use(function(req, res, next) {
  if (req.query.lang) {
    req.i18n.setLocaleFromQuery();
    res.cookie(config.locale.cookie, req.i18n.getLocale());
  } else {
    req.i18n.setLocaleFromCookie();
  }
  next();
})

这样您可以通过lang 查询参数更改语言,并使用cookie 存储使其永久化。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-02-19
    • 1970-01-01
    • 2019-08-12
    • 1970-01-01
    • 2013-08-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多