首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用i18n-2在express中创建多语言web应用程序

使用i18n-2在express中创建多语言web应用程序
EN

Stack Overflow用户
提问于 2015-05-11 01:45:04
回答 1查看 1.4K关注 0票数 2

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

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

这是我的配置:

代码语言:javascript
复制
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();
 });
EN

回答 1

Stack Overflow用户

发布于 2016-02-20 12:47:15

为了使所选语言永久化,需要安装一个名为cookie-parser的包

代码语言:javascript
复制
npm install --save cookie-parser

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

代码语言:javascript
复制
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存储使其成为永久性的。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30154594

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档