如何将app.js中的公共变量渲染到express中的所有路径

时间:2015-03-13 07:08:37

标签: node.js express handlebars.js

在我的Node.js应用程序中,一些渲染变量或每条路径都是常见的。每个路径上都有大约4-5个变量。我有大约20条路线。

目前我正在res.render

中的每个路径传递这些变量

是否有一种方法可以在某些地方传递这些公共变量'(例如:app.js)`每个路由都在使用它,以便我可以稍微清理一下我的代码。

我将express.js用于节点,handlebars用于模板。

编辑:我想我应该多解释一下

res.render('abc', {
                        commonitem1: 'one',
                        commonitem2: 'two',
                        ...
                   });

-------------------------------------
another route
res.render('xyz', {
                        commonitem1: 'one',
                        commonitem2: 'two',
                        ...
                   });

我想避免在我的每条路线中重复这种情况,并希望从一个普通的地方渲染它。

4 个答案:

答案 0 :(得分:6)

对于会话或请求相关值,您可以将这些公共值存储在全局变量中,然后直接在res.render中使用它们。为此,您有以下选项

  • 使用app.use存储值:

在你的app.js中添加一个中间件,为你做这件事。请记住在您定义的任何其他路由之前编写此中间件,因为中间件函数是按顺序执行的。

app.use(function(req, res, next){
    res.locals.items = "Value";
    next();
});
//your routes follow
app.use(‘/’, home);

在您的路线中,您可以将items直接放在res.render中,例如:

res.render('layout', {title: 'My awesome title',view: 'home', item :res.locals.items });
  • 使用express-session存储值:

如果你安装了快速会话,你可以在req.session.item中保存一些数据并将它们放在任何路径中,如:

res.render('layout', {title: 'My awesome title',view: 'home', item :req.session.items });

答案 1 :(得分:4)

似乎res.locals正是您要查找的内容 - 此对象会针对每个请求传递给您的视图,并且范围限定为每个单独的请求(即每个请求都可以拥有自己的res.locals版本)。所有请求都共享app.locals

我没有这方面的实际经验,但您可以使用此对象将所有变量传递给您的视图,或者Express可能会将app.locals中的任何内容与{{1}合并以及您通过res.locals发送给视图的内容。请仔细测试,我没有在官方文档中找到有关合并行为的相关信息。

至于填充res.render(),以保留代码DRY,您可以编写一个custom middleware,在您执行实际路由逻辑之前,使用您需要的任何内容填充对象

答案 2 :(得分:0)

// I created common func for all routes as below.

function commonRes(layout, req, res) {

  if (req.session.user) {
    res.render(layout, {
      user: req.session.user
      //csrfToken: req.csrfToken() // csrf 
    })

  } else {
    res.render(layout, {
      user: null,
      csrfToken: null
    })
  }

  return res.end()
}



// and apply it to all routes simply as below



app.get('/', (req, res) => {

  return commonRes('index.html', req, res)

})

app.get('/new', (req, res) => {

  return commonRes('new.html', req, res)
})

答案 3 :(得分:-1)

您可以使用以下代码

创建一个constants.js文件
(function (constants) {
    var FetchDataErrorMessage = "Error while fetching User Data";
    var ConnectionErroMessage = "Error while fetching Connecting Server";
    var InsertDataErrorMessage = "Error while inserting User Data";
    var RemoveDataErrorMessage = "Error while removing User Data";
    var UpdateDataErrorMessage = "Error while updating User Data";
})(module.exports);

在您需要使用这些变量的任何文件中,您可以添加以下代码。

var constants = require('constants');    
console.write(constants.RemoveDataErrorMessage);   
  

输出: - “删除用户数据时出错”