node.js - ExpressJS多语言路线

标签 node.js express routes multilingual

我刚刚进入 NodeJS/ExpressJS 开发,正在寻找一种使用 Express 创建多语言路由的方法。

app.get('/:language(en|nl)', function (req, res) {
    res.render('home', {
    });
});

app.get('/:language(en|nl)/news', function (req, res) {
    res.render('news', {
    });
 });    

这个想法是提取语言并在 MySQL 查询中使用它来获取请求语言的数据。 下面的代码获取了语言参数。

req.params.language

这给我留下了两个问题:

1)是否可以使用中间件来提取语言,而不是在每个路由中都这样做?

2) 如果我的网页包含两个用于在语言之间切换的国旗图标,确保它返回到同一页面但使用不同语言的最佳实践是什么,以及如何在 html 中构建 href ?我打算使用 Handlebars 作为模板引擎。

最佳答案

这是我到目前为止所想到的,而且相当简单。

它使语言之间的切换成为可能,并且当用户切换到另一种语言时,也使用户保持在同一页面上。

虽然还没有结束,但这是一个开始。

这只是回答我的第二个问题。语言参数仍然必须在每个路由中提供,但我现在并不介意。

app.js

var express = require('express');
var app = express();

var handlebars = require('express-handlebars')
.create({
    defaultLayout: 'main'
});
app.engine('handlebars', handlebars.engine);
app.set('view engine', 'handlebars');

app.set('port', process.env.PORT || 3000);

app.get('/', function (req, res) {
res.redirect('/nl');
});

app.get('/:language(en|nl)', function (req, res) {
res.render('home', {
    language: req.params.language,
    originalUrl: ''
});
});

app.get('/:language(en|nl)/news', function (req, res) {
res.render('news', {
    language: req.params.language,
    originalUrl: 'news'
});
});

// custom 404 page
app.use(function (req, res) {
res.type('text/plain');
res.status(404);
res.send('404 - Not Found');
});

// custom 500 page
app.use(function (err, req, res, next) {
console.error(err.stack);
res.type('text/plain');
res.status(500);
res.send('500 - Server Error');
});

app.listen(app.get('port'), function () {
console.log('Express started on http://localhost:' +
    app.get('port') + '; press Ctrl-C to terminate.');
});

main.handlebars

<!doctype html>
<html>

<head>
<title>Hello World</title>
<style type="text/css">
    .menu {
        margin: 0;
    }
    .menu > li  {
        display: inline-block;
        margin: 0;
        list-style: none;
    }
</style>
</head>

<body>
<ul class="menu">
    <li><a href="/{{language}}">Home</a></li>
    <li><a href="/{{language}}/news">News</a></li>
    <li><a href="/nl/{{originalUrl}}">Dutch</a></li>
    <li><a href="/en/{{originalUrl}}">English</a></li>
</ul>
{{{body}}}
</body>

</html>

home.handlebars

<h1>Home</h1>
<a href="/{{language}}/page1.html" >Navigation 1</a>
<a href="/{{language}}/page2.html" >Navigation 2</a>
<a href="/{{language}}/page3.html" >Navigation 3</a>

新闻. Handlebars

<h1>News</h1>
<h2>{{language}}</h2>

关于node.js - ExpressJS多语言路线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28460346/

相关文章:

javascript - express.js 和 mysql 身份验证

javascript - 尝试理解 Promise()

node.js - 如何实现 isTypeOf 方法?

ruby-on-rails - 仅针对某些操作的自定义路由路径

Docker-compose traefik PathPrefixStrip 无法正常工作

javascript - 父组件和其他父子组件之间的Angular 5 routerLink

node.js - 有没有办法在 zookeeper 中添加观察者队列?

javascript - 将 Chartist.JS 放入 Jade 中

node.js - 在 Express 服务器中使用 Google Speech API

express - Passport 反序列化用户方法从未被调用