如何在nodejs koa2和ejs中支持多语言

时间:2018-05-02 16:39:34

标签: javascript node.js ejs koa2

我尝试编写一个网页,它应该支持index.js

中的多语言
const Koa = require('koa');
const views = require('koa-views');
const path = require('path');
app.use(views(path.join(__dirname, './view'), {
    extension: 'ejs'
}));

app.use( async ( ctx ) => {
let title;
//some codes
if(language == "en") { //if the language is English
    title="Title";
}
else if(language == "de") { //if the language is German
    title="Titel";
}
await ctx.render('index', {
    title
});
});
app.listen(3000, ()=>{
  console.log('app runs on port 3000');
});

index.ejs

 <%=title%>

我运行此代码,它会很好地显示,现在我想在这个项目中添加一个语言包,例如language.json

{
"en":  {
    "site":  {
        "title":  "Title"
    }
},
"de": {
    "site":  {
        "title":  "Titel"
    }
 }
}

那么我应该如何更改index.jsindex.ejs

1 个答案:

答案 0 :(得分:0)

const Koa = require('koa');
const views = require('koa-views');
const path = require('path');
app.use(views(path.join(__dirname, './view'), {
    extension: 'ejs'
}));



const siteTitleLibrary = {
"en":  {
    "site":  {
        "title":  "Title"
    }
},
"de": {
    "site":  {
        "title":  "Titel"
    }
 }
};
// or 
// const siteTitleLibrary = require('language.json');

app.use( async ( ctx ) => {
await ctx.render('index', {
  site: siteTitleLibrary[language]
});
});
app.listen(3000, ()=>{
  console.log('app runs on port 3000');
});

然后在你的ejs中使用<%=site.title%>